Java項(xiàng)目中獲取路徑的絕對(duì)路徑問題和相對(duì)路徑問題
前言:
在純 Java 代碼里 我們一般都會(huì)用??class.getResource(String name)??? 或者 ??class.getClassLoader().getResource(String name)?? 兩種方法獲取文件的地址 (當(dāng)然不止這兩種方法)。今天就說說這兩種方法的異同。這里說的純 Java 代碼不是 Java web 項(xiàng)目。
1.目錄結(jié)構(gòu)

2.class.getResource(String name)
輸入:可以接受相對(duì)路徑(相對(duì)于該 class 類)或者絕對(duì)路徑(根目錄符號(hào)為 / 代表項(xiàng)目的根目錄 不代表硬盤的根目錄)
返回:URL 對(duì)象 該對(duì)象表示指向 name 的資源
// 獲取相對(duì)路徑 此時(shí)獲取的是該class文件的同級(jí)目錄
System.out.println("相對(duì)路徑:同級(jí)目錄下的配置文件>"+Main.class.getResource("demo.properties"));
// 獲取的絕對(duì)路徑 相對(duì)于跟目錄來說的
System.out.println("絕對(duì)路徑:同級(jí)目錄下的配置文件>"+Main.class.getResource("/com/xing/demo/demo.properties"));
System.out.println("相對(duì)路徑:上一級(jí)目錄下的配置文件>"+Main.class.getResource("../xing.properties"));
System.out.println("絕對(duì)路徑:根目錄下的配置文件>"+Main.class.getResource("/src.properties"));
// 當(dāng)傳入的是絕對(duì)路徑(帶有‘/')的時(shí)候,getresource()方法會(huì)從項(xiàng)目的根目錄開始解析路徑地址輸出:
相對(duì)路徑:同級(jí)目錄下的配置文件>file:/E:/ideawork/pathdemo/out/production/pathdemo/com/xing/demo/demo.properties
絕對(duì)路徑:同級(jí)目錄下的配置文件>file:/E:/ideawork/pathdemo/out/production/pathdemo/com/xing/demo/demo.properties
相對(duì)路徑:上一級(jí)目錄下的配置文件>file:/E:/ideawork/pathdemo/out/production/pathdemo/com/xing/xing.properties
絕對(duì)路徑:根目錄下的配置文件>file:/E:/ideawork/pathdemo/out/production/pathdemo/src.properties
3.class.getClassLoader().getResource(String name)
輸入:只能接受相對(duì)路徑 但此相對(duì)路徑是相對(duì)于根目錄來說的
返回:URL 對(duì)象
// src 在根目錄下 ?這里的同級(jí)也就是根目錄了
System.out.println("相對(duì)路徑:同級(jí)目錄下的配置文件>"+Main.class.getClassLoader().getResource("src.properties"));
System.out.println("相對(duì)路徑:相對(duì)根目錄的下一級(jí)目錄下的配置文件>"+Main.class.getClassLoader().getResource("com/com.properties"));
System.out.println("相對(duì)路徑:相對(duì)根目錄的下下一級(jí)目錄下的配置文件>"+Main.class.getClassLoader().getResource("com/xing/xing.properties"));輸出:
相對(duì)路徑:同級(jí)目錄下的配置文件>file:/E:/ideawork/pathdemo/out/production/pathdemo/src.properties
相對(duì)路徑:相對(duì)根目錄的下一級(jí)目錄下的配置文件>file:/E:/ideawork/pathdemo/out/production/pathdemo/com/com.properties
相對(duì)路徑:相對(duì)根目錄的下下一級(jí)目錄下的配置文件>file:/E:/ideawork/pathdemo/out/production/pathdemo/com/xing/xing.properties
注意:
/**
? * 下面兩種有相同的作用
? */
System.out.println("==相對(duì)路徑:同級(jí)目錄下的配置文件>"+Main.class.getResource("demo.properties"));
System.out.println("==相對(duì)路徑:相對(duì)根目錄的下下一級(jí)目錄下的配置文件>"+Main.class.getClassLoader().getResource("com/xing/demo/demo.properties"));輸出:
==相對(duì)路徑:同級(jí)目錄下的配置文件>file:/E:/ideawork/pathdemo/out/production/pathdemo/com/xing/demo/demo.properties
==相對(duì)路徑:相對(duì)根目錄的下下一級(jí)目錄下的配置文件>file:/E:/ideawork/pathdemo/out/production/pathdemo/com/xing/demo/demo.properties
3.1區(qū)別
兩者的區(qū)別:
其實(shí)我們看源碼就知道class.getResource 其實(shí)就是用的 class.getClassLoader().getResource(String name)。
只不過是class.getResource 會(huì)通過 resolveName 這個(gè)方法把傳入的路徑都轉(zhuǎn)換為符合 class.getClassLoader().getResource()的路徑 然后讓 getClassLoader 處理。
3.2ClassLoader
class.getClassLoader().getResource(String name) 使用的是 ClassLoader,而 ClassLoader 的獲取是有很多方法的。
獲取 classLoader 的方法:
- Thread.currentThread().getContextClassLoader()
- ClassLoader.getSystemClassLoader().
- class.getClassLoader()
System.out.println(Thread.currentThread().getContextClassLoader().getResource("src.properties"));
System.out.println(ClassLoader.getSystemClassLoader().getResource("src.properties"));輸出:
file:/E:/ideawork/pathdemo/out/production/pathdemo/src.properties
file:/E:/ideawork/pathdemo/out/production/pathdemo/src.properties
擴(kuò)展一下: 獲取項(xiàng)目的硬盤目錄 直到項(xiàng)目名級(jí)別的目錄
// 輸出:E:\sparkwork\pathdemo
System.out.println(System.getProperty("user.dir"));3.3關(guān)于 URL 的一些知識(shí)
URL fileURL = Main.class.getResource("/src.properties");
// 輸出:file:/E:/sparkwork/pathdemo/out/production/pathdemo/src.properties
System.out.println(fileURL.toURI());
// 輸出:/E:/sparkwork/pathdemo/out/production/pathdemo/src.properties
System.out.println(fileURL.getPath());
// 這兩種方法都是可以的?
File file = new File(fileURL.toURI());
Filw file2 = new File(fileURL.getPath())到此這篇關(guān)于Java項(xiàng)目中獲取路徑的絕對(duì)路徑問題和相對(duì)路徑問題的文章就介紹到這了,更多相關(guān)Java項(xiàng)目中獲取文件地址內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Event?Sourcing事件溯源模式優(yōu)化業(yè)務(wù)系統(tǒng)
這篇文章主要為大家介紹了Event?Sourcing事件溯源模式優(yōu)化業(yè)務(wù)系統(tǒng)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07
Mybatis讀取和存儲(chǔ)json類型數(shù)據(jù)的實(shí)現(xiàn)
本文主要介紹了Mybatis讀取和存儲(chǔ)json類型數(shù)據(jù)的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-06-06
基于Springboot實(shí)現(xiàn)定時(shí)發(fā)送郵件功能
這篇文章主要為大家詳細(xì)介紹了基于Springboot實(shí)現(xiàn)定時(shí)發(fā)送郵件功能的相關(guān)知識(shí),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-03-03
SpringBoot?Aop實(shí)現(xiàn)接口請求次數(shù)統(tǒng)計(jì)
我們通過Spring AOP在每次執(zhí)行方法前或執(zhí)行方法后進(jìn)行切面的處理,進(jìn)而統(tǒng)計(jì)方法訪問的次數(shù)等功能,本文主要介紹了SpringBoot?Aop實(shí)現(xiàn)接口請求次數(shù)統(tǒng)計(jì)2024-02-02
Java面試題 從源碼角度分析HashSet實(shí)現(xiàn)原理
這篇文章主要介紹了Java面試題 從源碼角度分析HashSet實(shí)現(xiàn)原理?,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-07-07
Spring中的@EnableScheduling定時(shí)任務(wù)注解
這篇文章主要介紹了Spring中的@EnableScheduling注解,@EnableScheduling是 Spring Framework 提供的一個(gè)注解,用于啟用 Spring 的定時(shí)任務(wù)功能,通過使用這個(gè)注解,可以在 Spring 應(yīng)用程序中創(chuàng)建定時(shí)任務(wù),需要的朋友可以參考下2024-01-01

