JavaRush /Java Blogu /Random-AZ /Səviyyə 31. Səviyyə mövzusu üzrə müsahibə suallarına cava...
DefNeo
Səviyyə

Səviyyə 31. Səviyyə mövzusu üzrə müsahibə suallarına cavablar

Qrupda dərc edilmişdir
Səviyyə 31. Səviyyə - 1 mövzusu üzrə müsahibə suallarına cavablar
  1. Obyekt Filehələ mövcud olmayan fayla uyğun gələ bilərmi?

    Bəli, əgər kataloq dəyərini konstruktora ötürsəniz.

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

    Bu, məsələn, bir sıra faylları əldə etmək üçün edilir.

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

    Nəticə:

    doğru yalan

    File-dən miras alır object. Cavab: bəli! Şərhlərinizi gözləyirəm.

  2. FileBir obyekti tipə necə çevirmək olar Path?

    MetodtoPath();

    toPath(); //Returns a java.nio.file.Path object constructed from the this abstract path.
  3. Files sinfi nə üçün lazımdır?

    Biz sinfi əsas götürdük File, ona bir az yenilik əlavə etdik, metodların adını dəyişdik və sonda onu da ikiyə böldük. Beləliklə, indi iki yeni sinif var - PathFiles.

    Path- bu, əslində, sinfin yeni analoqudur FileFiles- bu faydalı sinifdir ( Arrays& sinifləri ilə bənzətmə ilə Collections), sinfin bütün statik metodları ona köçürülmüşdür File. Bu, OOP.M baxımından "daha doğrudur"

    Sənədlərdən bəziləri:

    public final class Files
    extends Object

    Bu sinif yalnız fayllar, kataloqlar və ya digər fayl növləri üzərində işləyən statik metodlardan ibarətdir.
    Əksər hallarda, burada müəyyən edilmiş üsullar fayl əməliyyatlarını yerinə yetirmək üçün əlaqəli fayl sistemi provayderinə səlahiyyət verəcəkdir.

  4. Hansı arxiv dərslərini bilirsiniz?

    Bu mövzuda yaxşı məqalə və ondan bir parça: Java-da arxivləşdirmə

    Java spesifikasiyasında arxivlərlə işləmək üçün iki paket var - java.util.zipmüvafiq java.util.jarolaraq zip və jar arxivləri üçün. jar və zip formatları arasındakı fərq yalnız zip arxivinin genişləndirilməsindədir. Konstruktorların həyata keçirilməsi və sinif metodu istisna olmaqla, paket paketə java.util.jarbənzəyir . Yalnız paket aşağıda müzakirə olunacaq . Bütün nümunələri zip arxivindən istifadə etmək üçün çevirmək üçün kodun hər yerində Jar-ı Zip ilə əvəz etmək kifayətdir.java.util.zipvoidputNextEntry(ZipEntry e)JarOutputStreamjava.util.jar

  5. Kataloqu arxivə necə əlavə etmək olar?

    Özüm üçün bu sualı bitmiş arxivə boş bir kataloq əlavə etmək kimi başa düşdüm. Heç bir işlək nümunə tapmadım. Kod budur: (Aydın şəkildə göstərir ki, istənilən faylı arxivə yerləşdirə bilərsiniz, amma boş kataloqla... Necə cavab verim, StackOverFlow-da yazmadım, belə bir sual mütləq olacaq. aşağı səs verildi) Kimin təklifi varsa, yazsın.

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

    Sual son testDir haqqındadır, JVM onu əldə edilən arxivə qoymur, bütün digər txt faylları ilə yaxşı işləyir.

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

    Buradan kod

  6. Onlar niyə lazımdır Properties?

    Propertiesxassələri faylıdır. Onun strukturu: açar – dəyər. Bu cür fayllarla işləmək üçün Java-da sinif var Properties, ondan miras alınırHashTable<Object, Object>

    Onun manipulyasiyası haqqında bir məqalə var - Java Properties fayl nümunələri

  7. Faylda verilənlər hansı formada saxlanılır .properties?

    Əsas olan mənadır.

  8. PropertiesObyektdəki məlumatları fayldan yüklədikdən sonra onu dəyişdirmək mümkündürmü ?

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

Şərhlər
TO VIEW ALL COMMENTS OR TO MAKE A COMMENT,
GO TO FULL VERSION