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() 来完成路径的"重映射"操作。
相关推荐
biubiuibiu2 小时前
探秘新飞机:从包装到起飞的全程指南
数据库·python
racerun2 小时前
跳转链接批量解析工具 python
开发语言·python
q_35488851532 小时前
计算机毕业设计:Python当当网图书大数据分析平台 Django框架 爬虫 Pandas 可视化 大数据 大模型 书籍(建议收藏)✅
大数据·爬虫·python·机器学习·数据分析·django·课程设计
亚林瓜子2 小时前
linux账号强制密码过期导致私钥文件登录异常问题——(current) UNIX password:
linux·运维·服务器·ssh·aws·ec2·chage
庞轩px2 小时前
HotSpot详解——符号引用、句柄池、直接指针的终极解密
java·jvm·设计模式·内存·虚拟机·引用·klass
知智前沿2 小时前
什么是 RAG?通俗易懂讲解 + 核心流程梳理
人工智能·python
Code_LT2 小时前
【AIGC】Claude Code Rules配置
linux·ubuntu·aigc
LXY_BUAA2 小时前
《嵌入式操作系统》_驱动框架_20260318
linux·运维·服务器
淮北也生橘122 小时前
Linux应用开发:全链路 OTA 升级架构
linux·架构·ota·linux应用开发