JavaRush /Blog Java /Random-MS /Aras 31. Jawapan kepada soalan temu bual mengenai topik a...
DefNeo
Tahap

Aras 31. Jawapan kepada soalan temu bual mengenai topik aras

Diterbitkan dalam kumpulan
Tahap 31. Jawapan kepada soalan temu bual mengenai topik tahap - 1
  1. Bolehkah objek Filesepadan dengan fail yang belum wujud lagi?

    Ya, jika anda menghantar nilai direktori kepada pembina.

    String dirPath = "/";
    File f = new File(dirPath);
    File[] files = f.listFiles();

    Ini dilakukan, sebagai contoh, untuk mendapatkan pelbagai fail.

    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);
    
        }
    }

    Output:

    benar salah

    Filemewarisi daripada object. Jawapan: ya! Saya menunggu komen anda.

  2. Bagaimana untuk menukar objek Filekepada menaip Path?

    KaedahtoPath();

    toPath(); //Returns a java.nio.file.Path object constructed from the this abstract path.
  3. Mengapa kelas Fail diperlukan?

    Kami mengambil kelas sebagai asas File, menambah sedikit sesuatu yang baru padanya, menamakan semula kaedah, dan pada akhirnya juga membahagikannya kepada dua. Jadi sekarang terdapat dua kelas baharu - Pathdan Files.

    Path- ini, sebenarnya, analog baharu class File, dan Files- ini ialah kelas utiliti (dengan analogi dengan Arrays& classes Collections), semua kaedah statik kelas telah dipindahkan kepadanya File. Ini adalah "lebih betul" dari sudut pandangan OOP.M

    Beberapa daripada dokumen:

    public final class Files
    extends Object

    Kelas ini hanya terdiri daripada kaedah statik yang beroperasi pada fail, direktori atau jenis fail lain.
    Dalam kebanyakan kes, kaedah yang ditakrifkan di sini akan mewakilkan kepada pembekal sistem fail yang berkaitan untuk melaksanakan operasi fail.

  4. Apakah kelas pengarkiban yang anda tahu?

    Artikel yang bagus mengenai topik ini dan petikan daripadanya: Mengarkib di Jawa

    Terdapat dua pakej dalam spesifikasi Java untuk bekerja dengan arkib - java.util.zipdan java.util.jarmasing-masing untuk arkib zip dan jar. Perbezaan antara format jar dan zip hanya dalam lanjutan arkib zip. Pakej java.util.jaradalah serupa dengan pakej java.util.zip, kecuali untuk pelaksanaan pembina dan kaedah voidputNextEntry(ZipEntry e)kelas JarOutputStream. Hanya pakej yang akan dibincangkan di bawah java.util.jar. Untuk menukar semua contoh kepada menggunakan arkib zip, cuma gantikan Jar dengan Zip di mana-mana dalam kod.

  5. Bagaimana untuk menambah direktori ke arkib?

    Untuk diri saya sendiri, saya memahami soalan ini sebagai menambah direktori kosong pada arkib yang telah siap. Saya tidak menemui sebarang contoh yang berfungsi. Berikut adalah kodnya: (Ia jelas menunjukkan bahawa anda boleh meletakkan sebarang fail dalam arkib, tetapi dengan direktori kosong... Saya tidak tahu bagaimana untuk menjawab, saya tidak menyiarkan pada StackOverFlow, soalan sedemikian pasti akan menjadi downvoted) Jika sesiapa mempunyai sebarang cadangan, tulis.

    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();
            }
        }
    }

    Persoalannya ialah mengenai testDir terakhir, JVM tidak memasukkannya ke dalam arkib yang terhasil, dengan semua fail txt lain ia berfungsi dengan baik.

    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();
        }
    }

    Kod dari sini

  6. Mengapa mereka diperlukan Properties?

    Propertiesialah fail sifat. Strukturnya: kunci - nilai. Untuk bekerja dengan fail sedemikian, Java mempunyai class Properties, ia diwarisi daripadaHashTable<Object, Object>

    Terdapat artikel tentang memanipulasinya - contoh fail Java Properties

  7. Dalam bentuk apakah data disimpan dalam fail .properties?

    Kuncinya ialah makna.

  8. Adakah mungkin untuk menukar data dalam objek Propertiesselepas memuatkannya dari fail?

    Если он унаследован от 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

  9. Зачем нужен класс 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 предназначен для считывания потоков символов.

  10. Зачем нужен класс 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) специально ориентированы для работы с текстом и строками.

Komen
TO VIEW ALL COMMENTS OR TO MAKE A COMMENT,
GO TO FULL VERSION