Path 是路径抽象,不操作文件;Files 是 I/O 工具类,提供安全灵活的文件操作。二者配合实现跨平台、异常清晰、支持符号链接与权限的现代文件处理。

Java NIO.2 中的 Path 和 Files 类是现代文件操作的核心,取代了传统 java.io.File 的许多用法,更安全、更灵活、支持符号链接、权限控制和异步操作等。
Path:路径的抽象表示,不涉及实际文件操作
Path 是一个接口,代表文件系统中的路径(如 /home/user/docs/report.txt),它本身不检查路径是否存在,也不读写数据。它的作用是构造、解析、组合和标准化路径。
- 用
Paths.get()创建(推荐):Path p = Paths.get("/tmp", "data", "config.json");
自动适配操作系统分隔符(Windows 用\,Unix 用/) - 支持相对路径和绝对路径:
Path rel = Paths.get("logs/app.log");Path abs = Paths.get("/var/log/app.log"); - 常用路径操作:
p.getParent()→ 上级目录p.getFileName()→ 最后一段(如"config.json")p.toAbsolutePath()→ 转为绝对路径p.normalize()→ 处理..和.(如a/../b→b)
Files:真正执行I/O操作的工具类
Files 是一个全是静态方法的工具类,所有文件读写、复制、删除、属性访问等都通过它完成,且统一抛出 IOException 或其子类(如 NoSuchFileException),异常语义更清晰。
- 判断与检查:
Files.exists(p)、Files.isDirectory(p)、Files.isReadable(p) - 读取内容(小文件推荐):
Listlines = Files.readAllLines(p, StandardCharsets.UTF_8); byte[] data = Files.readAllBytes(p); - 写入内容:
Files.write(p, "hello".getBytes(), StandardOpenOption.CREATE, StandardOpenOption.TRUNCATE_EXISTING);
支持追加:StandardOpenOption.APPEND - 复制与移动:
Files.copy(src, dst, StandardCopyOption.REPLACE_EXISTING);Files.move(src, dst, StandardCopyOption.ATOMIC_MOVE); - 创建目录/文件:
Files.createDirectories(p);(自动创建多级父目录)Files.createFile(p);(仅当文件不存在时创建)
配合使用示例:安全读取配置文件
典型场景:确保路径存在、是普通文件、可读,再读取内容。
立即学习“Java免费学习笔记(深入)”;
Path configPath = Paths.get("conf", "app.properties");
try {
if (Files.isRegularFile(configPath) && Files.isReadable(configPath)) {
List lines = Files.readAllLines(configPath, StandardCharsets.UTF_8);
// 处理配置
} else {
throw new IOException("配置文件不可用: " + configPath);
}
} catch (IOException e) {
// 统一处理 I/O 异常
}
注意点和最佳实践
-
Path是轻量对象,可复用;Files方法是线程安全的,可并发调用 - 避免用
Path.toString()拼接路径——应始终用resolve():p.resolve("sub/file.txt")(正确)p.toString() + "/sub/file.txt"(错误,跨平台失效) - 大文件不要用
readAllBytes或readAllLines,改用Files.newBufferedReader或流式处理(Files.lines()) - 临时文件建议用
Files.createTempFile(),自动处理命名与清理










