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() 来完成路径的"重映射"操作。
相关推荐
尚早立志2 分钟前
Spring Boot 源码研读之ConfigurableEnvironment 环境准备
java·spring boot·后端
YuK.W2 分钟前
Leetcode100: 94.二叉树中序遍历、104.二叉树最大深度、226.翻转二叉树
java·算法·leetcode·二叉树
乂爻yiyao10 分钟前
0. openems 部署与体验
java·openems
TanYYF17 分钟前
spring ai入门教程一
java·人工智能·spring
掉鱼的猫22 分钟前
用 ChatModel 构建 LLM 驱动的 Java 应用
java·llm
41541125 分钟前
JTS 空间运算实战:线 × 线、线 × 面、面 × 面叠加分析
java·jts·叠加分析
2601_9563198839 分钟前
2026年下半年AI量化学习,分清表达开发和验证
人工智能·python
.Hypocritical.42 分钟前
数据结构笔记——链表成环/反转 + 有序二叉树(BST)构建、遍历、删除
java·数据结构
2023自学中43 分钟前
imx6ull 开发板, mame 模拟器,运行游戏 测试
linux·游戏·嵌入式·开发板
只会写代码1 小时前
一套开箱即用实体反射Lambda链式工具,彻底告别原生反射样板代码
java·程序员·源码