JavaRush /Java блогу /Random-KY /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, жана - бул пайдалуу класс ( & класстарга Filesаналогия боюнча ), класстын бардык статикалык ыкмалары ага өткөрүлүп берилген . Бул OOP.M көз карашынан караганда "туурараак"ArraysCollectionsFile

    Документтерден кээ бирлери:

    public final class Files
    extends Object

    Бул класс файлдар, каталогдор же башка типтеги файлдарда иштеген статикалык методдордон гана турат.
    Көпчүлүк учурларда, бул жерде аныкталган ыкмалар файл операцияларын аткаруу үчүн байланышкан файл тутумунун провайдерине өткөрүп берет.

  4. Кандай архивдик класстарды билесиз?

    Бул тема боюнча жакшы макала жана андан үзүндү: Java менен архивдөө

    Java спецификациясында архивдер менен иштөө үчүн java.util.zipжана java.util.jarzip жана jar архивдери үчүн эки пакет бар. jar жана zip форматтарынын айырмасы zip архивинин кеңейтorшинде гана. Пакет конструкторлорду ишке ашыруудан жана класстык методдон башка 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 аны алынган архивге салbyte, башка бардык 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