JavaRush /Blogue Java /Random-PT /Nível 31. Respostas às perguntas da entrevista sobre o tó...
DefNeo
Nível 36

Nível 31. Respostas às perguntas da entrevista sobre o tópico do nível

Publicado no grupo Random-PT
Nível 31. Respostas às perguntas da entrevista sobre o tema do nível - 1
  1. Um objeto pode Filecorresponder a um arquivo que ainda não existe?

    Sim, se você passar o valor do diretório para o construtor.

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

    Isso é feito, por exemplo, para obter um array de arquivos.

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

    Saída:

    verdadeiro falso

    Fileherda de object. Resposta: sim! Estou aguardando seus comentários.

  2. Como converter um objeto Fileem tipo Path?

    MétodotoPath();

    toPath(); //Returns a java.nio.file.Path object constructed from the this abstract path.
  3. Por que a classe Arquivos é necessária?

    Tomamos a classe como base File, adicionamos algo novo a ela, renomeamos os métodos e, no final, também dividimos em dois. Portanto, agora existem duas novas classes - Pathe Files.

    Path- este é, de fato, um novo análogo da classe File, e Files- esta é uma classe utilitária (por analogia com as classes Arrays& Collections), todos os métodos estáticos da classe foram transferidos para ela File. Isso é “mais correto” do ponto de vista do OOP.M

    Alguns dos documentos:

    public final class Files
    extends Object

    Esta classe consiste exclusivamente em métodos estáticos que operam em arquivos, diretórios ou outros tipos de arquivos.
    Na maioria dos casos, os métodos definidos aqui delegarão ao provedor do sistema de arquivos associado a execução das operações de arquivo.

  4. Que classes de arquivamento você conhece?

    Um bom artigo sobre este tópico e um trecho dele: Arquivamento em Java

    Existem dois pacotes na especificação Java para trabalhar com arquivos - java.util.zipe java.util.jarrespectivamente para arquivos zip e jar. A diferença entre os formatos jar e zip está apenas na extensão do arquivo zip. Um pacote java.util.jaré semelhante a um pacote java.util.zip, exceto pela implementação de construtores e um método voidputNextEntry(ZipEntry e)de classe JarOutputStream. Apenas o pacote será discutido abaixo java.util.jar. Para converter todos os exemplos para usar um arquivo zip, basta substituir Jar por Zip em todo o código.

  5. Como adicionar um diretório a um arquivo?

    Para mim, entendi essa questão como adicionar um diretório vazio a um arquivo finalizado. Não encontrei nenhum exemplo funcional. Aqui está o código: (Mostra claramente que você pode colocar qualquer arquivo no arquivo, mas com um diretório vazio... Não sei responder, não postei no StackOverFlow, essa pergunta com certeza será voto negativo) Se alguém tiver alguma sugestão, escreva.

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

    A dúvida é sobre o último testDir, a JVM não o coloca no arquivo resultante, com todos os outros arquivos txt funciona bem.

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

    Código daqui

  6. Por que eles são necessários Properties?

    Propertiesé um arquivo de propriedades. Sua estrutura: chave – valor. Para trabalhar com esses arquivos, Java possui uma classe Properties, ela é herdada deHashTable<Object, Object>

    Há um artigo sobre como manipulá-lo - exemplos de arquivos de propriedades Java

  7. De que forma os dados são armazenados no arquivo .properties?

    A chave é o significado.

  8. É possível alterar os dados de um objeto Propertiesapós carregá-lo de um arquivo?

    Se for herdado de HashMap, então você pode, só então precisará cancelar a gravação das alterações neste arquivo. Existe um método para isso setProperty.

    Aqui está o código:

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

Comentários
TO VIEW ALL COMMENTS OR TO MAKE A COMMENT,
GO TO FULL VERSION