-
オブジェクトは
File
まだ存在しないファイルに対応できますか?はい、ディレクトリ値をコンストラクターに渡す場合は可能です。
String dirPath = "/"; File f = new File(dirPath); File[] files = f.listFiles();
これは、たとえばファイルの配列を取得するために行われます。
public class MyClass { public static void main(String[] args) { boolean isObject = false; File file = new File("/"); if (file instanceof Object){ isObject = true; } boolean isFile = file.isFile(); // Tests whether the file denoted by this abstract pathname is a normal file. Это из documentации System.out.println(isObject + " "+ isFile); } }
出力:
true falseFile
から継承しますobject
。答え: はい! コメントをお待ちしています。 -
オブジェクトを
File
型に変換するにはどうすればよいですかPath
?方法
toPath();
toPath(); //Returns a java.nio.file.Path object constructed from the this abstract path.
-
Files クラスが必要な理由は何ですか?
このクラスをベースとして
File
、それに少し新しいものを追加し、メソッドの名前を変更し、最後にクラスを 2 つに分割しました。したがって、Path
とという 2 つの新しいクラスが追加されましたFiles
。Path
- これは、実際には class の新しい類似物でありFile
、 - これは ( & classesFiles
と同様に) ユーティリティ クラスであり、クラスのすべての静的メソッドがそれに転送されています。OOP.M の観点からすると、これは「より正しい」です。Arrays
Collections
File
ドキュメントからの一部:
public final class Files
extends Object
このクラスは、ファイル、ディレクトリ、またはその他の種類のファイルを操作する静的メソッドのみで構成されます。
ほとんどの場合、ここで定義されたメソッドは、関連するファイル システム プロバイダーにファイル操作の実行を委任します。 -
どのようなアーカイブ クラスを知っていますか?
このトピックに関する優れた記事とその抜粋: Java でのアーカイブ
Java 仕様には、アーカイブを操作するための 2 つのパッケージがあり、
java.util.zip
それぞれjava.util.jar
zip アーカイブと jar アーカイブ用です。jar 形式と zip 形式の違いは、zip アーカイブの拡張子のみです。パッケージは、コンストラクターとクラスメソッドの実装を除き、java.util.jar
パッケージと似ています。以下ではパッケージについてのみ説明します。zip アーカイブを使用するようにすべての例を変換するには、コード内のあらゆる場所で Jar を Zip に置き換えるだけです。java.util.zip
voidputNextEntry(ZipEntry e)
JarOutputStream
java.util.jar
-
アーカイブにディレクトリを追加するにはどうすればよいですか?
私自身、この質問は完成したアーカイブに空のディレクトリを追加するものだと理解していました。実用的な例は見つかりませんでした。コードは次のとおりです: (これは、アーカイブに任意のファイルを置くことができることを明確に示していますが、空のディレクトリを使用します...どう答えるべきかわかりません。StackOverFlow に投稿したわけではありません。そのような質問は間違いなく行われます。反対票)誰かが提案がある場合は、書いてください。
public class Main { public static void main(String[] args) { String[] myFiles = {"D:\\forJava\\MyArtifactName\\packForTest\\res2.txt", "D:\\forJava\\MyArtifactName\\packForTest\\res.txt", "D:\\forJava\\MyArtifactName\\packForTest\\res4.txt", "D:\\forJava\\MyArtifactName\\packForTest\\testDir\\" }; String zipFile = "D:\\forJava\\MyArtifactName\\packForTest\\res.zip"; ZipUtility zipUtil = new ZipUtility(); try { zipUtil.zip(myFiles, zipFile); } catch (Exception ex) { // some errors occurred ex.printStackTrace(); } } }
質問は最後の testDir に関するものですが、JVM はそれを結果のアーカイブに配置しませんが、他のすべての txt ファイルは正常に動作します。
ZipUtility.java
:import java.io.BufferedInputStream; import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import java.util.ArrayList; import java.util.List; import java.util.zip.ZipEntry; import java.util.zip.ZipOutputStream; public class ZipUtility { private static final int BUFFER_SIZE = 4096; public void zip(List<File> listFiles, String destZipFile) throws IOException { ZipOutputStream zos = new ZipOutputStream(new FileOutputStream(destZipFile)); for (File file : listFiles) { if (file.isDirectory()) { zipDirectory(file, file.getName(), zos); } else { zipFile(file, zos); } } zos.flush(); zos.close(); } public void zip(String[] files, String destZipFile) throws IOException { List<File> listFiles = new ArrayList<File>(); for (int i = 0; i < files.length; i++) { listFiles.add(new File(files[i])); } zip(listFiles, destZipFile); } private void zipDirectory(File folder, String parentFolder, ZipOutputStream zos) throws IOException { for (File file : folder.listFiles()) { if (file.isDirectory()) { zipDirectory(file, parentFolder + "/" + file.getName(), zos); continue; } zos.putNextEntry(new ZipEntry(parentFolder + "/" + file.getName())); BufferedInputStream bis = new BufferedInputStream( new FileInputStream(file)); long bytesRead = 0; byte[] bytesIn = new byte[BUFFER_SIZE]; int read = 0; while ((read = bis.read(bytesIn)) != -1) { zos.write(bytesIn, 0, read); bytesRead += read; } zos.closeEntry(); } } private void zipFile(File file, ZipOutputStream zos) throws IOException { zos.putNextEntry(new ZipEntry(file.getName())); BufferedInputStream bis = new BufferedInputStream(new FileInputStream( file)); long bytesRead = 0; byte[] bytesIn = new byte[BUFFER_SIZE]; int read = 0; while ((read = bis.read(bytesIn)) != -1) { zos.write(bytesIn, 0, read); bytesRead += read; } zos.closeEntry(); } }
ここからのコード
-
なぜ必要なのでしょうか
Properties
?Properties
プロパティファイルです。その構造: キー – 値。このようなファイルを操作するために、Java にはクラスがありProperties
、それは次から継承されます。HashTable<Object, Object>
それを操作することに関する記事があります - Java プロパティ ファイルの例
-
データはどのような形式でファイルに保存されますか
.properties
?鍵となるのは意味です。
-
Properties
ファイルからオブジェクトをロードした後に、オブジェクト内のデータを変更することはできますか?Если он унаследован от
HashMap
, тогда можно, только потом нужно будет изменения в этот файл отписать. Для этого есть методsetProperty
.Вот code:
import java.io.FileInputStream; import java.io.IOException; import java.io.InputStream; import java.util.Properties; /** * Created by Роман on 12.09.2016. */ public class LoadAndSetProperties { public static void main(String[] args) { Properties prop = new Properties(); InputStream input = null; try { input = new FileInputStream("D:\\forJava\\MyArtifactName\\packForTest\\config.properties"); // load a properties file prop.load(input); // get the property value and print it out prop.setProperty("database", "ddfdfdfdfdf"); System.out.print(prop.getProperty("database")); } catch (IOException ex) { ex.printStackTrace(); } finally { if (input != null) { try { input.close(); } catch (IOException e) { e.printStackTrace(); } } } } }
Вывод:
ddfdfdfdfdf -
Зачем нужен класс
FileReader
?Java Docs:
public class FileReader
extends InputStreamReader
Convenience class for reading character files. The constructors of this class assume that the default character encoding and the default byte-buffer size are appropriate. To specify these values yourself, construct an InputStreamReader on a FileInputStream.
FileReader is meant for reading streams of characters.
Класс для чтения символов файлов. Конструкторы этого класса предполагают, что codeировка символов дефолтная и дефолтный размер буфера являются подходящими. Whatбы задать эти значения самостоятельно, следует построить
InputStreamReader
надFileInputStream
.FileReader
предназначен для считывания потоков символов. -
Зачем нужен класс
FileWriter
?public class FileWriter
extends OutputStreamWriter
Convenience class for writing character files. The constructors of this class assume that the default character encoding and the default byte-buffer size are acceptable. To specify these values yourself, construct an OutputStreamWriter on a FileOutputStream.
Whether or not a file is available or may be created depends upon the underlying platform. Some platforms, in particular, allow a file to be opened for writing by only one FileWriter (or other file-writing object) at a time. In such situations the constructors in this class will fail if the file involved is already open. FileWriter is meant for writing streams of characters.
Класс для записи символов файлов. Конструкторы этого класса предполагают, что codeировка символов дефолтная и дефолтный размер буфера являются приемлемым. Whatбы задать эти значения самостоятельно, следует построить
OutputStreamWriter
надFileOutputStream
. Является ли файл доступен для записи, зависит от используемой платформы. Некоторые платформы разрешают держать файл для записи только однимFileWriter
(or другого an object записи file), в одно время.FileWriter
предназначен для записи потоков символов. Для написания потоков необработанных byteов, используйтеFileOutputStream
.Эти классы (
FileReader
иFileWriter
) специально ориентированы для работы с текстом и строками.
DefNeo
レベル 36
GO TO FULL VERSION