File类的getPath()、getAbsolutePath()、getCanonicalPath()

本文通过实例演示了Java中File类提供的getPath()、getAbsolutePath()和getCanonicalPath()方法的区别与联系,解释了这些方法如何处理绝对路径和相对路径。

File类提供了getPath()、getAbsolutePath()、getCanonicalPath()三个方法来提供文件路径,本文将通过下面的实例演示它们的区别与联系:

public class FileTest {

    static void printPath(String path){
        System.out.println("输入:" + path);
        File file = new File(path);
        printPath(file);
    }

    static void printPath(File file){
        System.out.println(file.getPath());
        System.out.println(file.getAbsolutePath());
        try {
            System.out.println(file.getCanonicalPath());
        } catch (IOException e) {
            System.err.println("Error occurs when invoking getCanonicalPath()");
        }
        System.out.println();
    }

    public static void main(String[] args) {
        printPath("C:\\Users\\qwer\\Desktop\\osu\\图解HTTP.pdf");
        printPath("图解HTTP.pdf");
        printPath(".\\图解HTTP.pdf");
        printPath("..\\不存在的目录\\图解HTTP.pdf");
    }

}

结果为:
输入:C:\Users\qwer\Desktop\osu\图解HTTP.pdf
C:\Users\qwer\Desktop\osu\图解HTTP.pdf
C:\Users\qwer\Desktop\osu\图解HTTP.pdf
C:\Users\qwer\Desktop\osu\图解HTTP.pdf

输入:图解HTTP.pdf
图解HTTP.pdf
D:\eclipsepreferences\Tests\图解HTTP.pdf
D:\eclipsepreferences\Tests\图解HTTP.pdf

输入:.\图解HTTP.pdf
.\图解HTTP.pdf
D:\eclipsepreferences\Tests\.\图解HTTP.pdf
D:\eclipsepreferences\Tests\图解HTTP.pdf

输入:..\不存在的目录\图解HTTP.pdf
..\不存在的目录\图解HTTP.pdf
D:\eclipsepreferences\Tests\..\不存在的目录\图解HTTP.pdf
D:\eclipsepreferences\不存在的目录\图解HTTP.pdf

用于测试的路径中,第一个是绝对路径,后三个都是相对路径。从输出结果中,可以得出几点结论:
(1)对于绝对路径,三种方法的输出结果相同。
(2)对于相对路径,getPath()不做任何处理,输出路径等于输入路径;getAbsolutePath()简单地将当前工作目录(即项目文件夹路径,本文中为D:\eclipsepreferences\Tests\)与输入的相对路径拼接在一起,包括.\与..\;getCanonicalPath()会在getAbsolutePath()的基础上解析出完整的路径。
(3)Java中,相对路径的根默认在项目文件夹路径。
(4)getCanonicalPath()返回的必定是绝对路径。

### `Java File getPath()` 方法的作用 `File.getPath()` 是 Java 中 `java.io.File` 的一个方法,用于获取文件或目录的路径字符串。该方法返回的是构造 `File` 对象时使用的原始路径字符串,但会对其中的文件分隔符进行规范化处理。 #### 作用详解 - **返回原始路径**:如果创建 `File` 对象时使用的是相对路径,则 `getPath()` 返回的就是该相对路径字符串,而不是从根目录开始的完整路径。 - **规范化路径分隔符**:此方法会自动修正路径中的分隔符问题,例如重复的分隔符、不同操作系统下的分隔符差异等。例如,构造 `File` 对象时传入 `"test\\file.txt"`,在 Windows 系统上会返回 `"test\file.txt"`,而在 Linux 系统上则会返回 `"test/file.txt"` [^1]。 - **不解析符号链接或相对路径**:与 `getAbsolutePath()` 和 `getCanonicalPath()` 不同,`getPath()` 不会将相对路径转换为绝对路径,也不会解析路径中的特殊符号(如 `.` 或 `..`)。 #### 示例代码 以下是一个简单的示例,演示了 `getPath()` 的行为: ```java import java.io.File; public class FilePathExample { public static void main(String[] args) { File file = new File("data/../docs/report.txt"); System.out.println(file.getPath()); } } ``` 输出结果: ``` data\..\docs\report.txt ``` 尽管路径中包含 `..`,`getPath()` 仍然直接返回构造时使用的字符串,并未解析这些符号。 #### 使用场景 - **保留用户输入路径**:当需要保留用户提供的原始路径格式时,可以使用 `getPath()`。例如,在日志记录或配置文件中存储路径信息时,不需要将其转换为绝对路径。 - **调试路径问题**:在调试文件操作逻辑时,可以通过 `getPath()` 查看程序内部使用的路径是否符合预期。 - **跨平台兼容性处理**:由于 `getPath()` 会规范化路径分隔符,因此可以在不同操作系统下统一处理路径拼接问题。 #### 注意事项 - **路径有效性**:即使文件或目录不存在,`getPath()` 依然会返回构造时使用的路径字符串,因为该方法并不检查文件是否存在。 - **相对路径依赖当前工作目录**:如果构造 `File` 对象时使用的是相对路径,则实际访问的文件位置会受到当前工作目录的影响,而 `getPath()` 返回的仍然是相对路径形式。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值