JavaRush /جاوا بلاگ /Random-UR /لیول 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، اور - یہ ایک یوٹیلیٹی کلاس ہے ( & classes Filesکے ساتھ مشابہت سے )، کلاس کے تمام جامد طریقے اس میں منتقل کر دیے گئے ہیں ۔ یہ OOP.M کے نقطہ نظر سے "زیادہ درست" ہے۔ArraysCollectionsFile

    دستاویزات میں سے کچھ:

    public final class Files
    extends Object

    یہ کلاس خاص طور پر جامد طریقوں پر مشتمل ہے جو فائلوں، ڈائریکٹریز، یا فائلوں کی دیگر اقسام پر کام کرتی ہے۔
    زیادہ تر معاملات میں، یہاں بیان کیے گئے طریقے فائل آپریشنز کو انجام دینے کے لیے متعلقہ فائل سسٹم فراہم کنندہ کو تفویض کریں گے۔

  4. آپ کونسی آرکائیونگ کلاسز جانتے ہیں؟

    اس موضوع پر ایک اچھا مضمون اور اس کا ایک اقتباس: جاوا میں آرکائیونگ

    آرکائیوز کے ساتھ کام کرنے کے لیے جاوا کی تفصیلات میں دو پیکیجز ہیں - java.util.zipاور java.util.jarبالترتیب زپ اور جار آرکائیوز کے لیے۔ جار اور زپ فارمیٹس کے درمیان فرق صرف زپ آرکائیو کی توسیع میں ہے۔ ایک پیکیج java.util.jarپیکیج کی طرح ہے java.util.zip، سوائے کنسٹرکٹرز کے نفاذ اور voidputNextEntry(ZipEntry e)کلاس کے طریقہ کار کے JarOutputStream۔ ذیل میں صرف پیکیج پر بات کی جائے گی java.util.jar۔ تمام مثالوں کو زپ آرکائیو استعمال کرنے کے لیے تبدیل کرنے کے لیے، کوڈ میں ہر جگہ صرف جار کو زپ سے بدل دیں۔

  5. آرکائیو میں ڈائریکٹری کو کیسے شامل کیا جائے؟

    اپنے لیے، میں نے اس سوال کو ختم شدہ آرکائیو میں خالی ڈائرکٹری شامل کرنے کے طور پر سمجھا۔ مجھے کام کرنے کی کوئی مثال نہیں ملی۔ یہ کوڈ ہے: (یہ واضح طور پر ظاہر کرتا ہے کہ آپ کسی بھی فائل کو آرکائیو میں رکھ سکتے ہیں، لیکن ایک خالی ڈائرکٹری کے ساتھ... میں نہیں جانتا کہ جواب کیسے دیا جائے، میں نے StackOverFlow پر پوسٹ نہیں کی، ایسا سوال ضرور ہوگا downvoted) اگر کسی کے پاس کوئی تجویز ہے تو لکھیں۔

    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پراپرٹیز فائل ہے۔ اس کی ساخت: کلید – قدر۔ ایسی فائلوں کے ساتھ کام کرنے کے لیے جاوا کی ایک کلاس ہوتی ہے Properties، یہ وراثت میں ملتی ہے۔HashTable<Object, Object>

    اس میں جوڑ توڑ کے بارے میں ایک مضمون ہے - جاوا پراپرٹیز فائل کی مثالیں۔

  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