所以我必须使用Java文件树系统,因为.listfiles文件由于某种原因在通过远程网络时非常慢。但是,所有Java文件树系统示例都列出了子目录中的所有文件,严重降低了程序的速度。如何才能使它只搜索目录并仅返回该目录中的文件夹和文件的名称,而不是子目录。
示例代码:
package javaapplication6;
import java.io.IOException;
import java.nio.file.FileVisitResult;
import java.nio.file.FileVisitor;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;
import java.nio.file.SimpleFileVisitor;
import java.nio.file.attribute.BasicFileAttributes;
/** Recursive listing with SimpleFileVisitor in JDK 7. */
public final class JavaApplication6 {
public static void main(String... aArgs) throws IOException{
String ROOT = "\\\\directory";
FileVisitor<Path> fileProcessor = new ProcessFile();
Files.walkFileTree(Paths.get(ROOT), fileProcessor);
}
private static final class ProcessFile extends SimpleFileVisitor<Path> {
@Override public FileVisitResult visitFile(
Path aFile, BasicFileAttributes aAttrs
) throws IOException {
System.out.println("Processing file:" + aFile);
return FileVisitResult.CONTINUE;
}
@Override public FileVisitResult preVisitDirectory(
Path aDir, BasicFileAttributes aAttrs
) throws IOException {
System.out.println("Processing directory:" + aDir);
return FileVisitResult.CONTINUE;
}
}
}
非常感谢任何见解或帮助,谢谢。
答案 0 :(得分:0)
使用目录流似乎更快速,更轻松地工作。
答案 1 :(得分:0)
使用较长版本的walkFileTree
方法,您可以像这样设置maxDepth
:
Files.walkFileTree(Paths.get(ROOT), EnumSet.noneOf(FileVisitOption.class),
1, fileProcessor);
请注意,与更简单的情况不同,ROOT的子目录将生成对visitFile
的调用。更常见的是,maxDepth级别的子目录会生成对visitFile
的调用,但不会调用preVisitDirectory
和postVisitDirectory
。