JavaRush /Java блогы /Random-KK /Деңгей 31. Деңгейлік тақырып бойынша сұхбат сұрақтарына ж...
DefNeo
Деңгей

Деңгей 31. Деңгейлік тақырып бойынша сұхбат сұрақтарына жауаптар

Топта жарияланған
31-деңгей. Деңгей тақырыбы бойынша сұхбат сұрақтарына жауаптар – 1
  1. Нысан 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. Жауап: иә! Пікірлеріңізді күтемін.

  2. Объектіні Fileтипке қалай түрлендіруге болады Path?

    ӘдісtoPath();

    toPath(); //Returns a java.nio.file.Path object constructed from the this abstract path.
  3. Files класы не үшін қажет?

    Біз сыныпты негізге алдық File, оған кішкене жаңалық қостық, әдістердің атын өзгерттік, соңында оны да екіге бөлдік. Енді екі жаңа сынып бар - Pathжәне Files.

    Path- бұл шын мәнінде сыныптың жаңа аналогы Fileжәне - бұл утorта класы ( & Filesсыныптарымен ұқсастығы бойынша ), оған класстың барлық статикалық әдістері ауыстырылды . Бұл OOP.M тұрғысынан «дұрысырақ».ArraysCollectionsFile

    Құжаттардың кейбірі:

    public final class Files
    extends Object

    Бұл сынып тек файлдарда, каталогтарда немесе файлдардың басқа түрлерінде жұмыс істейтін статикалық әдістерден тұрады.
    Көп жағдайда осы жерде анықталған әдістер файл әрекеттерін орындау үшін байланысты файлдық жүйе провайдеріне өкілдік береді.

  4. Қандай мұрағаттау сабақтарын білесіз?

    Осы тақырып бойынша жақсы мақала және одан үзінді: Java тілінде мұрағаттау

    Java спецификациясында мұрағаттармен жұмыс істеуге арналған екі пакет бар - java.util.zipсәйкесінше java.util.jarzip және jar мұрағаттары үшін. Jar және zip пішімдерінің айырмашылығы тек zip мұрағатының кеңейтілімінде. Пакет конструкторларды жүзеге асырудан және класс әдісінен басқа java.util.jarпакетке ұқсас . Тек пакет туралы төменде талқыланады . Барлық мысалдарды zip мұрағатын пайдалану үшін түрлендіру үшін codeтың барлық жерінде Jar-ды Zip-пен ауыстырыңыз.java.util.zipvoidputNextEntry(ZipEntry e)JarOutputStreamjava.util.jar

  5. Каталогты мұрағатқа қалай қосуға болады?

    Мен өзім үшін бұл сұрақты дайын мұрағатқа бос каталог қосу деп түсіндім. Мен жұмыс істейтін мысалдарды таппадым. Міне, code: (Бұл архивке кез келген файлды қоюға болатынын анық көрсетеді, бірақ бос каталогпен... Мен қалай жауап беру керектігін білмеймін, мен 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();
        }
    }

    Осы жерден code

  6. Олар не үшін қажет Properties?

    Propertiesқасиеттер файлы болып табылады. Оның құрылымы: кілт – құндылық. Мұндай файлдармен жұмыс істеу үшін Java-да класс бар Properties, ол мұраланғанHashTable<Object, Object>

    Оны манипуляциялау туралы мақала бар - Java Properties файлының мысалдары

  7. Файлда деректер қандай формада сақталады .properties?

    Ең бастысы - мағына.

  8. Нысандағы деректерді 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

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

Пікірлер
TO VIEW ALL COMMENTS OR TO MAKE A COMMENT,
GO TO FULL VERSION