Path 是路径抽象,不操作文件;Files 是 I/O 工具类,提供安全灵活的文件操作。二者配合实现跨平台、异常清晰、支持符号链接与权限的现代文件处理。
Java NIO.2 中的 Path 和 Files 类是现代文件操作的核心,取代了传统 java.io.File 的许多用法,更安全、更灵活、支持符号链接、权限控制和异步操作等。
Path 是一个接口,代表文件系统中的路径(如 /home/user/docs/report.txt),它本身不检查路径是否存在,也不读写数据。它的作用是构造、解析、组合和标准化路径。
Paths.get() 创建(推荐):Path p = Paths.get("/tmp", "data", "config.json");\,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 是一个全是静态方法的工具类,所有文件读写、复制、删除、属性访问等都通过它完成,且统一抛出 IOException 或其子类(如 NoSuchFileException),异常语义更清晰。
Files.exists(p)、Files.isDirectory(p)、Files.isReadable(p)
List lines = 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);(仅当文件不存在时创建)典型场景:确保路径存在、是普通文件、可读,再读取内容。
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.c
reateTempFile(),自动处理命名与清理