Java中FileVisitor遍历目录树的核心是Files.walkFileTree()配合自定义访问器,实现深度优先、安全可控的遍历;其接口含preVisitDirectory、visitFile、visitFileFailed、postVisitDirectory四个关键回调方法,分别对应目录进入前、文件访问时、访问失败时、目录退出后四种状态。
Java 中使用 FileVisitor 遍历目录树,核心是借助 Files.walkFileTree() 方法配合自定义的访问器实现深度优先、安全可控的遍历,比递归调用 File.listFiles() 更健壮,天然支持符号链接处理、异常中断和细粒度控制。
FileVisitor 是一个泛型接口(FileVisitor),主要定义四个回调方法,分别对应遍历过程中的不同节点状态:
CONTINUE、SKIP_SUBTREE、TERMINATE)最简方式是继承 SimpleFileVisitor —— 它已为所有方法提供了默认返回 CONTINUE 的实现,只需重写关心的方法即可:
Files.walkFileTree(Paths.get("/home/user/docs"), new SimpleFileVisitor() {
@Override
public FileVisitResult visitFile(Path file, BasicFileAttributes attrs) {
if (file.toString().endsWith(".log")) {
System.out.println("找到日志文件:" + file);
}
return FileVisitResult.CONTINUE;
}
@Override
public FileVisitResult visitFileFailed(Path file, IOException exc) {
System.err.println("跳过无法访问的文件:" + f
ile + ",原因:" + exc.getMessage());
return FileVisitResult.CONTINUE; // 继续遍历其他文件
}
});
通过返回特定枚举值,可在运行时动态调整遍历逻辑:
preVisitDirectory 中判断目录名,返回 SKIP_SUBTREE
TERMINATE
visitFile 和 preVisitDirectory 中用外部变量累加(注意多线程下需同步)FileVisitor 时传入 EnumSet.of(FileVisitOption.FOLLOW_LINKS) 作为 walkFileTree 的第二个参数相比手写递归 + File.listFiles():
StackOverflowError
基本上就这些。掌握这四个回调的触发时机和返回含义,就能写出清晰、健壮、可扩展的目录遍历逻辑。