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, указывающий на недопустимую ячейку памяти. Нулевой указатель буквально не указывает на в любом месте , который отличается от указаний на местоположение, которое оказывается недопустимым.)
Не уверенный, как Вы хотите представить дерево? Так или иначе вот пример, который сканирует все поддерево с помощью рекурсии. Файлы и каталоги рассматривают одинаково. Обратите внимание что 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;
}
});
}
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() );
}
}
}
Это отображает неотчетливо файлы и папки.
Видят методы в классе Файла, чтобы заказать им или избежать, чтобы каталог распечатал и т.д.
Apache выезда палата общин FileUtils (listFiles, iterateFiles, и т.д.). Хорошие удобные методы для того, чтобы сделать то, что Вы хотите и также применение фильтров.
http://commons.apache.org/io/api-1.4/org/apache/commons/io/FileUtils.html
Можно также использовать 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();
}});
}
}
В JDK7, "больше функций NIO" должно иметь методы для применения шаблона "посетитель" по дереву файла или просто непосредственному содержанию каталога - никакая потребность найти все файлы в потенциально огромном каталоге прежде, чем выполнить итерации по ним.