-
האם אובייקט יכול
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); } }
פלט:
נכון שקרFile
יורש מobject
. תשובה: כן! אני מחכה להערות שלך. -
כיצד להמיר אובייקט
File
לכתבPath
?שיטה
toPath();
toPath(); //Returns a java.nio.file.Path object constructed from the this abstract path.
-
מדוע יש צורך במחלקה Files?
לקחנו את הכיתה כבסיס
File
, הוספנו לה משהו חדש, שינינו את שמות השיטות, ובסוף גם חילקנו אותה לשניים. אז עכשיו יש שני כיתות חדשות -Path
וFiles
.Path
- זהו, למעשה, אנלוגי חדש של המחלקהFile
, ו-Files
זוהי מחלקת עזר (באנלוגיה למחלקותArrays
&Collections
), כל השיטות הסטטיות של המחלקה הועברו אליהFile
. זה "נכון יותר" מנקודת המבט של OOP.Mחלק מהמסמכים:
public final class Files
extends Object
מחלקה זו מורכבת אך ורק משיטות סטטיות הפועלות על קבצים, ספריות או סוגים אחרים של קבצים.
ברוב המקרים, השיטות המוגדרות כאן יאצילו לספק מערכת הקבצים המשויך לביצוע פעולות הקבצים. -
אילו שיעורי ארכיון אתה מכיר?
מאמר טוב בנושא זה וקטע ממנו: ארכיון ב-Java
ישנן שתי חבילות במפרט Java לעבודה עם ארכיונים -
java.util.zip
ובהתאמהjava.util.jar
לארכיוני zip ו-jar. ההבדל בין פורמטים של jar ל-zip הוא רק בהרחבה של ארכיון ה-zip. חבילהjava.util.jar
דומה לחבילהjava.util.zip
, למעט יישום של בנאים ושיטתvoidputNextEntry(ZipEntry e)
מחלקהJarOutputStream
. רק החבילה תידון להלןjava.util.jar
. כדי להמיר את כל הדוגמאות לשימוש בארכיון zip, פשוט החלף את Jar ב-Zip בכל מקום בקוד. -
כיצד להוסיף ספרייה לארכיון?
בעצמי, הבנתי את השאלה הזו כהוספת ספרייה ריקה לארכיון גמור. לא מצאתי דוגמאות עובדות. הנה הקוד: (זה מראה בבירור שאפשר לשים כל קובץ בארכיון, אבל עם ספרייה ריקה... אני לא יודע איך לענות, לא פרסמתי ב-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
?המפתח הוא המשמעות.
-
האם ניתן לשנות את הנתונים באובייקט
Properties
לאחר טעינתו מקובץ?אם הוא עבר בירושה מ
HashMap
, אז אתה יכול, רק אז תצטרך לבטל את כתיבת השינויים בקובץ זה. יש שיטה לזהsetProperty
.הנה הקוד:
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
רָמָה
GO TO FULL VERSION