Как просканировать папку в Java?

NullPointerException s - исключения, возникающие при попытке использовать ссылку, которая указывает на отсутствие местоположения в памяти (null), как если бы она ссылалась на объект. Вызов метода по нулевой ссылке или попытка получить доступ к полю нулевой ссылки вызовет функцию NullPointerException. Они наиболее распространены, но другие способы перечислены на странице NullPointerException javadoc.

Вероятно, самый быстрый пример кода, который я мог бы придумать для иллюстрации NullPointerException, be:

public class Example {

    public static void main(String[] args) {
        Object obj = null;
        obj.hashCode();
    }

}

В первой строке внутри main я явно устанавливаю ссылку Object obj равной null. Это означает, что у меня есть ссылка, но она не указывает на какой-либо объект. После этого я пытаюсь обработать ссылку так, как если бы она указывала на объект, вызывая метод на нем. Это приводит к NullPointerException, потому что нет кода для выполнения в местоположении, на которое указывает ссылка.

(Это техничность, но я думаю, что она упоминает: ссылка, которая указывает на null, равна 't то же, что и указатель C, указывающий на недопустимую ячейку памяти. Нулевой указатель буквально не указывает на в любом месте , который отличается от указаний на местоположение, которое оказывается недопустимым.)

58
задан Lipis 8 May 2012 в 12:01
поделиться

5 ответов

Не уверенный, как Вы хотите представить дерево? Так или иначе вот пример, который сканирует все поддерево с помощью рекурсии. Файлы и каталоги рассматривают одинаково. Обратите внимание что File.listFiles () пустой указатель возвратов для некаталогов.

public static void main(String[] args) {
    Collection<File> all = new ArrayList<File>();
    addTree(new File("."), all);
    System.out.println(all);
}

static void addTree(File file, Collection<File> all) {
    File[] children = file.listFiles();
    if (children != null) {
        for (File child : children) {
            all.add(child);
            addTree(child, all);
        }
    }
}

Java 7 предлагает несколько улучшений. Например, DirectoryStream обеспечивает один результат за один раз - вызывающая сторона больше не должна ожидать всех операций ввода-вывода для завершения перед действием. Это позволяет возрастающие обновления GUI, раннюю отмену, и т.д.

static void addTree(Path directory, Collection<Path> all)
        throws IOException {
    try (DirectoryStream<Path> ds = Files.newDirectoryStream(directory)) {
        for (Path child : ds) {
            all.add(child);
            if (Files.isDirectory(child)) {
                addTree(child, all);
            }
        }
    }
}

Примечание, что страшное пустое возвращаемое значение было заменено IOException.

Java 7 также предлагает дерево Уокер :

static void addTree(Path directory, final Collection<Path> all)
        throws IOException {
    Files.walkFileTree(directory, new SimpleFileVisitor<Path>() {
        @Override
        public FileVisitResult visitFile(Path file, BasicFileAttributes attrs)
                throws IOException {
            all.add(file);
            return FileVisitResult.CONTINUE;
        }
    });
}
71
ответ дан volley 24 November 2019 в 18:51
поделиться
import java.io.File;
public class Test {
    public static void main( String [] args ) {
        File actual = new File(".");
        for( File f : actual.listFiles()){
            System.out.println( f.getName() );
        }
    }
}

Это отображает неотчетливо файлы и папки.

Видят методы в классе Файла, чтобы заказать им или избежать, чтобы каталог распечатал и т.д.

http://java.sun.com/javase/6/docs/api/java/io/File.html

21
ответ дан OscarRyz 24 November 2019 в 18:51
поделиться

Apache выезда палата общин FileUtils (listFiles, iterateFiles, и т.д.). Хорошие удобные методы для того, чтобы сделать то, что Вы хотите и также применение фильтров.

http://commons.apache.org/io/api-1.4/org/apache/commons/io/FileUtils.html

18
ответ дан Brandon DuRette 24 November 2019 в 18:51
поделиться

Можно также использовать FileFilter интерфейс для отфильтровывания то, что Вы хотите. Это лучше всего используется при создании анонимного класса, который реализует его:

import java.io.File;
import java.io.FileFilter;

public class ListFiles {
    public File[] findDirectories(File root) { 
        return root.listFiles(new FileFilter() {
            public boolean accept(File f) {
                return f.isDirectory();
            }});
    }

    public File[] findFiles(File root) {
        return root.listFiles(new FileFilter() {
            public boolean accept(File f) {
                return f.isFile();
            }});
    }
}
6
ответ дан Leonel 24 November 2019 в 18:51
поделиться

В JDK7, "больше функций NIO" должно иметь методы для применения шаблона "посетитель" по дереву файла или просто непосредственному содержанию каталога - никакая потребность найти все файлы в потенциально огромном каталоге прежде, чем выполнить итерации по ним.

0
ответ дан Tom Hawtin - tackline 24 November 2019 в 18:51
поделиться
Другие вопросы по тегам:

Похожие вопросы: