JavaRush /Blog Java /Random-PL /Poziom 31. Odpowiedzi na pytania podczas rozmowy kwalifik...
DefNeo
Poziom 36

Poziom 31. Odpowiedzi na pytania podczas rozmowy kwalifikacyjnej na temat poziomu

Opublikowano w grupie Random-PL
Poziom 31. Odpowiedzi na pytania z rozmowy kwalifikacyjnej na temat poziomu - 1
  1. Czy obiekt może Fileodpowiadać plikowi, który jeszcze nie istnieje?

    Tak, jeśli przekażesz wartość katalogu konstruktorowi.

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

    Odbywa się to na przykład w celu uzyskania tablicy plików.

    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.
    Это из dokumentации
            System.out.println(isObject + " "+ isFile);
    
        }
    }

    Wynik:

    prawda, fałsz

    Filedziedziczy od object. Odpowiedź: tak! Czekam na Twoje komentarze.

  2. Jak przekonwertować obiekt Filena typ Path?

    metodatoPath();

    toPath(); //Returns a java.nio.file.Path object constructed from the this abstract path.
  3. Dlaczego potrzebna jest klasa Files?

    Za podstawę przyjęliśmy tę klasę File, dodaliśmy do niej coś nowego, zmieniliśmy nazwy metod, a na koniec podzieliliśmy ją na dwie części. Więc teraz są dwie nowe klasy - Pathi Files.

    Path- jest to w istocie nowy odpowiednik klasy Fileoraz Files- jest to klasa użytkowa (analogicznie do klas Arrays& Collections), do której przeniesiono wszystkie statyczne metody tej klasy File. Jest to „bardziej poprawne” z punktu widzenia OOP.M

    Niektóre z dokumentów:

    public final class Files
    extends Object

    Ta klasa składa się wyłącznie z metod statycznych, które działają na plikach, katalogach lub plikach innych typów.
    W większości przypadków zdefiniowane tutaj metody zostaną przekazane powiązanemu dostawcy systemu plików w celu wykonania operacji na plikach.

  4. Jakie znasz klasy archiwizujące?

    Dobry artykuł na ten temat i jego fragment: Archiwizacja w Javie

    W specyfikacji Java dostępne są dwa pakiety do pracy z archiwami - java.util.ziporaz java.util.jarodpowiednio do archiwów ZIP i JAR. Różnica między formatami jar i zip polega jedynie na rozszerzeniu archiwum zip. Pakiet java.util.jarjest podobny do pakietu java.util.zip, z wyjątkiem implementacji konstruktorów i metody voidputNextEntry(ZipEntry e)klasowej JarOutputStream. Poniżej zostanie omówiony jedynie pakiet java.util.jar. Aby przekonwertować wszystkie przykłady tak, aby korzystały z archiwum ZIP, po prostu zamień Jar na Zip w całym kodzie.

  5. Jak dodać katalog do archiwum?

    Dla siebie zrozumiałem to pytanie jako dodanie pustego katalogu do gotowego archiwum. Nie znalazłem żadnych działających przykładów. Oto kod: (Wyraźnie pokazuje, że możesz umieścić dowolny plik w archiwum, ale z pustym katalogiem... Nie wiem, jak odpowiedzieć, nie pisałem na StackOverFlow, takie pytanie na pewno będzie downvoted) Jeśli ktoś ma jakieś sugestie, pisać.

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

    Pytanie dotyczy ostatniego katalogu testowego, JVM nie umieszcza go w wynikowym archiwum, ze wszystkimi innymi plikami txt działa dobrze.

    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 stąd

  6. Dlaczego są potrzebne Properties?

    Propertiesjest plikiem właściwości. Jego struktura: klucz – wartość. Aby pracować z takimi plikami, Java ma klasę Properties, z której jest dziedziczonaHashTable<Object, Object>

    Jest artykuł o manipulowaniu nim - przykłady plików Java Properties

  7. W jakiej formie dane są przechowywane w pliku .properties?

    Kluczem jest znaczenie.

  8. Czy można zmienić dane w obiekcie Propertiespo wczytaniu go z pliku?

    Если он унаследован от HashMap, тогда можно, только потом нужно будет изменения в этот файл отписать. Для этого есть метод setProperty.

    Вот kod:

    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.

    Класс для чтения символов файлов. Конструкторы этого класса предполагают, что kodировка символов дефолтная и дефолтный размер буфера являются подходящими. Coбы задать эти значения самостоятельно, следует построить 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.

    Класс для записи символов файлов. Конструкторы этого класса предполагают, что kodировка символов дефолтная и дефолтный размер буфера являются приемлемым. Coбы задать эти значения самостоятельно, следует построить OutputStreamWriter над FileOutputStream. Является ли файл доступен для записи, зависит от используемой платформы. Некоторые платформы разрешают держать файл для записи только одним FileWriter (Lub другого obiektа записи plik), в одно время. FileWriter предназначен для записи потоков символов. Для написания потоков необработанных bajtов, используйте FileOutputStream.

    Эти классы (FileReader и FileWriter) специально ориентированы для работы с текстом и строками.

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