JavaRush /مدونة جافا /Random-AR /المستوى 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. لماذا هناك حاجة إلى فئة الملفات؟

    لقد اتخذنا الفصل كأساس File، وأضفنا شيئًا جديدًا إليه، وأعدنا تسمية الطرق، وفي النهاية قسمناه أيضًا إلى قسمين. إذن هناك الآن فئتان جديدتان - Pathو Files.

    Path- هذا، في الواقع، نظير جديد للفئة File، و- Filesهذه فئة فائدة (قياسًا على الفئة Arrays& Collections)، تم نقل جميع الأساليب الثابتة للفئة إليها File. وهذا "الأصح" من وجهة نظر OOP.M

    بعض من الوثائق:

    public final class Files
    extends Object

    تتكون هذه الفئة حصريًا من الأساليب الثابتة التي تعمل على الملفات أو الأدلة أو أنواع الملفات الأخرى.
    في معظم الحالات، سيتم تفويض الطرق المحددة هنا إلى موفر نظام الملفات المرتبط لتنفيذ عمليات الملف.

  4. ما هي فئات الأرشفة التي تعرفها؟

    مقالة جيدة عن هذا الموضوع ومقتطف منه: الأرشفة في جافا

    توجد حزمتان في مواصفات Java للعمل مع الأرشيفات - java.util.zipوعلى java.util.jarالتوالي لأرشيفات Zip وJar. الفرق بين تنسيقات jar وzip يكمن فقط في امتداد الأرشيف المضغوط. الحزمة java.util.jarتشبه الحزمة java.util.zip، باستثناء تنفيذ المنشئات وطريقة voidputNextEntry(ZipEntry e)الفصل JarOutputStream. سيتم مناقشة الحزمة فقط أدناه java.util.jar. لتحويل جميع الأمثلة لاستخدام أرشيف مضغوط، ما عليك سوى استبدال Jar بـ Zip في كل مكان في الكود.

  5. كيفية إضافة دليل إلى الأرشيف؟

    بالنسبة لي، فهمت هذا السؤال على أنه إضافة دليل فارغ إلى الأرشيف النهائي. لم أجد أي أمثلة عملية. هذا هو الكود: (يوضح بوضوح أنه يمكنك وضع أي ملف في الأرشيف، ولكن مع وجود دليل فارغ... لا أعرف كيف أجيب، لم أنشر على 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();
        }
    }

    الكود من هنا

  6. لماذا هم بحاجة Properties؟

    Propertiesهو ملف خصائص. هيكلها: مفتاح – قيمة. للعمل مع مثل هذه الملفات، تحتوي Java على فئة Properties، وهي موروثة منهاHashTable<Object, Object>

    هناك مقالة حول التعامل معها - أمثلة على ملفات خصائص Java

  7. في أي شكل يتم تخزين البيانات في الملف .properties؟

    والمفتاح هو المعنى.

  8. هل من الممكن تغيير البيانات في كائن Propertiesبعد تحميله من ملف؟

    إذا تم توريثه من HashMap، فيمكنك ذلك، وعندها فقط ستحتاج إلى إلغاء كتابة التغييرات على هذا الملف. هناك طريقة لهذا setProperty.

    إليك الكود:

    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