358. Java IO API - 使用 relativize() 创建路径之间的相对关系

文章目录

  • [358. Java IO API - 使用 `relativize()` 创建路径之间的相对关系](#358. Java IO API - 使用 relativize() 创建路径之间的相对关系)
      • [🧠 方法语法](#🧠 方法语法)
      • [✅ 示例 1:兄弟路径(sibling paths)](#✅ 示例 1:兄弟路径(sibling paths))
      • [✅ 示例 2:父子路径](#✅ 示例 2:父子路径)
      • [❗ 注意事项](#❗ 注意事项)
      • [💡 实际应用:构造目标路径](#💡 实际应用:构造目标路径)
      • [🧾 总结表](#🧾 总结表)
      • [📌 小技巧](#📌 小技巧)

358. Java IO API - 使用 relativize() 创建路径之间的相对关系

在编写文件 I/O 代码时,一个常见的需求是:从路径 A 到路径 B 的"相对路径"是什么?

Java 提供了 Path.relativize() 方法,用于构造一个从当前路径出发,到达目标路径的相对路径。


🧠 方法语法

java 复制代码
Path relativePath = basePath.relativize(targetPath);
  • 它返回一个 Path,表示basePathtargetPath 的路径差异
  • 如果 basePath/a/b/c,而 targetPath/a/b/d/e,则结果就是 ../d/e

✅ 示例 1:兄弟路径(sibling paths)

java 复制代码
Path p1 = Paths.get("joe");
Path p2 = Paths.get("sally");

Path fromJoeToSally = p1.relativize(p2);
Path fromSallyToJoe = p2.relativize(p1);

System.out.println(fromJoeToSally); // ../sally
System.out.println(fromSallyToJoe); // ../joe

📌 解释

  • joesally 是同一层级目录,想从 joesally,需要先回到上一级(..),再进入 sally

✅ 示例 2:父子路径

java 复制代码
Path p1 = Paths.get("home");
Path p3 = Paths.get("home/sally/bar");

Path fromHomeToBar = p1.relativize(p3);
Path fromBarToHome = p3.relativize(p1);

System.out.println(fromHomeToBar); // sally/bar
System.out.println(fromBarToHome); // ../..

📌 解释

  • homehome/sally/bar,就是往下走两个目录。
  • home/sally/barhome,则需要往上退两层。

❗ 注意事项

  1. 两个路径必须都是相对的或都是绝对的 ,否则会抛出 IllegalArgumentException
java 复制代码
// 错误示例:混合使用相对路径和绝对路径
Paths.get("/home").relativize(Paths.get("data/file.txt")); // ❌ 会抛异常
  1. 如果两个路径没有共同根(比如不同的盘符 C:\ vs D:\),无法计算相对路径。

💡 实际应用:构造目标路径

我们经常会将 relativize()resolve() 搭配使用:

java 复制代码
Path sourceDir = Paths.get("/home/joe");
Path targetFile = Paths.get("/home/joe/docs/report.txt");

// 获取相对于 sourceDir 的路径
Path relative = sourceDir.relativize(targetFile); // docs/report.txt

// 现在可以将这个路径 "移植" 到另一个目录下
Path backupDir = Paths.get("/mnt/backup");
Path backupFile = backupDir.resolve(relative); // /mnt/backup/docs/report.txt

📦 这在递归复制、迁移、备份路径结构时非常实用


🧾 总结表

路径 A 路径 B A.relativize(B)
joe sally ../sally
home home/sally/bar sally/bar
home/sally/bar home ../..
/a/b /a/c/d ../c/d
/data/log data/logs (相对) ❌ 错误(混类型)

📌 小技巧

  • 想象你的路径是一棵树,relativize() 就是从一棵分支走向另一棵分支的最短路线。
  • 可以用它结合 resolve() 来完成路径的"重映射"操作。
相关推荐
safestar20126 小时前
ES批量写入性能调优:BulkProcessor 参数详解与实战案例
java·大数据·运维·jenkins
还在忙碌的吴小二6 小时前
Harness 最佳实践:Java Spring Boot 项目落地 OpenSpec + Claude Code
java·开发语言·spring boot·后端·spring
风吹迎面入袖凉6 小时前
【Redis】Redis的五种核心数据类型详解
java·redis
weixin_156241575766 小时前
基于YOLOv8深度学习花卉识别系统摄像头实时图片文件夹多图片等另有其他的识别系统可二开
大数据·人工智能·python·深度学习·yolo
夕除6 小时前
javaweb--02
java·tomcat
AI_Claude_code6 小时前
ZLibrary访问困境方案三:Web代理与轻量级转发服务的搭建与优化
爬虫·python·web安全·搜索引擎·网络安全·web3·httpx
小陈工6 小时前
2026年4月7日技术资讯洞察:下一代数据库融合、AI基础设施竞赛与异步编程实战
开发语言·前端·数据库·人工智能·python
ailvyuanj6 小时前
2026年Java AI开发实战:Spring AI完全指南
java
时空无限6 小时前
ansible 由于不同主机 python 版本不同执行报错
python·ansible
ZhengEnCi6 小时前
P2E-Python字典操作完全指南-从增删改查到遍历嵌套的Python编程利器
python