成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

詳解Java SE 7文件操作之路徑操作

開發 后端
Java SE 7中對Path類的操作主要有兩種:對路徑的操作和對文件的操作。這篇文章中我們就來了解一下對路徑的操作。

Java SE 7中對Path類的操作主要有兩種:對路徑的操作和對文件的操作。這篇文章中我們就來了解一下對路徑的操作。

創建Path實例
Path實例包含了指定文件或目錄位置的信息,在實例化Path類時,需要指定一個或多個目錄或文件名。路徑的根目錄不是必須的;路徑信息可能僅僅是一個目錄或文件的名稱。
最簡單的創建Path實例的方式就是使用Paths(注意這里有一個s)類的get方法: 
 

  1. Path p1 = Paths.get("/tmp/foo");   
  2.   Path p2 = Paths.get(args[0]);   
  3.   Path p3 = Paths.get("file:///Users/joe/FileTest.java");   



Path類接受String或URI作為參數。

獲取路徑信息
前面我們已經說過了,File System一般是樹形結構,因此我們可以把Path理解為按順序存儲的一系列的名稱(目錄名稱和文件名稱)。目錄結構中***一層的目錄名就是序列中 index為0的那一個,目錄結構中***一層的目錄名或者文件名就是序列中index為n-1的那一個(這里n是路徑中層次的數目)。Path類提供方法來通過index獲取序列中的一個元素或一個子序列。
隨后的例子中我們使用的目錄結構如下圖:

    下面的代碼定義了一個Path對象并獲取其中的信息。要注意的是這些代碼中除了isHidden方法外,其他的方法并不需要指定的目錄或文件存在;如果不存在,isHidden方法會拋出異常。
 

Java代碼
  1. Path path = Paths.get("C:\\home\\joe\\foo");    // Microsoft Windows syntax     
  2. //Path path = Paths.get("/home/joe/foo");    // Solaris syntax     
  3. System.out.format("toString: %s%n", path.toString());     
  4. System.out.format("getName: %s%n", path.getName());     
  5. System.out.format("getName(0): %s%n", path.getName(0));     
  6. System.out.format("getNameCount: %d%n", path.getNameCount());     
  7. System.out.format("subpath(0,2): %d%n", path.subpath(0,2));     
  8. System.out.format("getParent: %s%n", path.getParent());     
  9. System.out.format("getRoot: %s%n", path.getRoot());     
  10. System.out.format("isHidden: %s%n", path.isHidden());    


下面是這段代碼的輸出情況



上面的代碼中我們創建Path時使用的是絕對路徑,下面我們來看看創建路徑時使用相對路徑時,這段代碼的執行結果:
 

Java代碼

  1. //Path path = Paths.get("sally/bar");     // Solaris syntax     
  2. Path path = Paths.get("sally\\bar");    // Microsoft Windows syntax    


大家可以自行去實驗一下具體的輸出是什么。

去除Path中的冗余
在很多文件系統中我們使用'.'來代表當前目錄,使用'..'代表父目錄。在有些情況下我們創建的路徑中會有冗余的路徑信息,例如:
        /home/./joe/foo
        /home/sally/../joe/foo
方法normalize會去除這些冗余信息,包括'.'或'directory/..'。上面的兩個例子在去除冗余信息后都是/home/joe/foo。
要注意的是normalize方法并不去檢查文件系統,它只是簡單的進行語法操作。在第二個例子中,如果sally是一個指向其他的目錄的符號鏈接,那么去除了sally/..后可能導致Path不在指向原來的文件或目錄。
如果你需要清除冗余信息,又要保證結果仍然指向正確的文件或目錄,可以使用toRealPath方法。在下面我們會講到這個方法。

轉換Path
有3個方法用來轉換Path。
    * toUri方法
      如果你需要將Path轉換為可以在瀏覽器中打開的字符串格式,可以使用toUri方法,例如:
 

Java代碼
 
  1. Path p1 = Paths.get("/home/logfile");     
  2. System.out.format("%s%n", p1.toUri());  // 結果是 file:///home/logfile    

      注意在這里即使/home/logfile'指向的目錄或文件不存在,這段代碼同樣能夠執行成功。
    * toAbsolutePath方法
      該方法將路徑轉換為絕對路徑。如果原來的Path已經是絕對路徑,該方法直接返回原有的Path對象。
      我們來看看下面的例子:
 
Java代碼
  1. Path path = Paths.get("home\\joe\\foo");     
  2. Path absolutePath = path.toAbsolutePath();     
  3. System.out.println(path == absolutePath); //結果是false     
  4.     
  5. Path path2 = Paths.get("c:\\home\\joe\\foo ");     
  6. Path absolutePath2 = path2.toAbsolutePath();     
  7. System.out.println(path2 == absolutePath2);//結果是true    


      同樣的,toAbsolutePath方法并不需要Path所指向的文件或目錄存在。
    * toRealPath方法
      這個方法會返回一個已經存在的文件或目錄的真實路徑(如果文件或目錄不存在或無法訪問,該方法會拋出異常)。該方法會執行以下的操作:
      如果傳入的參數是true并且文件系統支持符號鏈接,則解析路徑中存在的符號鏈接(如果有的話)。
      如果原來的Path是相對路徑,將其轉換成絕對路徑。
      如果路徑中含有冗余信息,返回的Path中這些冗余信息會被去除。


連接兩個Path
可以使用resolve方法來將兩個Path連接起來。該方法的參數是一個字符串。如果該字符串代表的是一個相對路徑,那么這個路徑會被擴展到原來的路徑后。如果傳入的字符串是一個絕對路徑,那么返回的值就是傳入的這個絕對路徑。例如:
 

Java代碼
  1. Path p1 = Paths.get("C:\\home\\joe\\foo");        
  2. System.out.format("%s%n", p1.resolve("bar")); // 結果是 C:\home\joe\foo\bar     
  3.     
  4. Paths.get("foo").resolve("c:\\home\joe");       // 結果是  C:\home\joe    


創建兩個路徑之間的路徑
這個功能說起來有些繞口,實際的功能就是創建兩個指定的目錄或文件之間的相對路徑。例如:
 

Java代碼
  1. Path p1 = Paths.get("joe/foo");     
  2. Path p2 = Paths.get("sally");    


在這個例子中,由于兩個路徑都是相對路徑,沒有其他的信息,我們會認為這兩個joe和sally是同一級的兄弟目錄,因此有以下的結果
 

Java代碼
  1. Path p1_to_p2 = p1.relativize(p2);   // 結果是 ../../sally     
  2. Path p2_to_p1 = p2.relativize(p1);   // 結果是 ../joe/foo   


讓我們看看另外一個例子:
 

Java代碼
  1. Path p1 = Paths.get("home");     
  2. Path p3 = Paths.get("home/sally/bar");     
  3. Path p1_to_p3 = p1.relativize(p3);  // 結果是 sally/bar     
  4. Path p3_to_p1 = p3.relativize(p1);  // 結果是 ../..   


在這個例子中,兩個路徑共享同一個節點-home,所以結果并不是../home/sally/bar和../../../home.
如果兩個路徑中有一個是絕對路徑,另外一個是相對路徑,relative方法會拋出異常。如果兩個路徑都是絕對路徑,那么relative方法的行為和系統相關,不同的系統可能不同。
我在Windows操作系統下實驗了一下,如果兩個路徑屬于同一個硬盤,那么可以執行成功,否則會拋出異常。
 

Java代碼
  1. Path path1 = Paths.get("c:\\abcd\\efg");     
  2. Path path2 = Paths.get("c:\\temp");     
  3. System.out.println(path1.relativize(path2));        //結果是..\..\temp     
  4. System.out.println(path2.relativize(path1));        //結果是..\abcd\efg     
  5.     
  6. Path path3 = Paths.get("c:\\abcd\\efg");     
  7. Path path4 = Paths.get("d:\\temp");     
  8. System.out.println(path3.relativize(path4));        //拋出異常    


Path的比較
Path提供equals方法來檢查兩個Path是否相等。但是這里要注意的是比較的并不是兩個Path是否指向同一個目錄或者文件。請看下面的例子:
 

Java代碼
  1. Path path1 = Paths.get("abcd\\123");     
  2. Path path2 = Paths.get("abcd\\123");     
  3. Path path3 = Paths.get("abcd\\.\\123");     
  4. System.out.println(path1.equals(path2));        //true     
  5. System.out.println(path1.equals(path3));        //false     
  6. System.out.println(path1.equals(path3.normalize())); //true     
  7. System.out.println(path1.equals(path1.toAbsolutePath()));        //false    


Path類還提供了startsWith和endsWith方法,這兩個方法用來檢查路徑是否以指定的字符串開始或者結束,例如:
 

Java代碼
  1. Path path = ...;     
  2. Path otherPath = ...;     
  3. Path beginning = Paths.get("/home");     
  4. Path ending = Paths.get("foo");     
  5.     
  6. if (path.equals(otherPath)) {     
  7.     //equality logic here     
  8. else if (path.startsWith(beginning)) {     
  9.     //path begins with "/home"     
  10. else if (path.endsWith(ending)) {     
  11.     //path ends with "foo"     
  12. }    


Path類實現了Iterable接口,iterator方法會返回一個Iterator對象,該對象中的***個元素就是原路徑中最上層(最靠近根節點)的目錄。下面是使用這個方法的例子:
 

Java代碼
  1. Path path = ...;     
  2. for (Path name: path) {     
  3.     System.out.println(name);     
  4. }   


Path類還實現了Comparable接口,因此可以使用compareTo來比較兩個Path。比較的算法和結果是和文件系統的提供者和系統平臺相關的。大家在使用之前,***先實驗一下。
Path 類還提供了一個方法isSameFile來檢查兩個Path是否指向同一個目錄或文件。如果作為參數的Path為null,那么會直接返回false,不會去檢查Path指向的文件是否存在。如果兩Path來自不同的文件系統提供者,那么也會直接返回false,不會去檢查文件或目錄是否存在。如果兩個 Path執行equals方法的返回結果為true,那么這個方法直接返回true,也不會去檢查文件或目錄是否存在。其他的情況下是否會去打開或訪問 Path指向的文件或目錄是與具體的實現相關的,也就是說不同的JDK/JRE可能會有不同的行為。
驗證文件或目錄是否存在
上面所介紹的很多方法都不會去驗證Path指向的文件或目錄是否存在,只是操作Path實例自身。但是在有些情況下,你需要訪問文件系統來驗證文件、目錄存在與否,這時你可以使用exists和notExists方法。需要注意的是!path.exists()并不等于path.notExists()。當你調用這兩個方法時,有以下3中情況:

    * 文件或者目錄被證實存在
    * 文件或者目錄被證實不存在
    * 不知道文件或目錄是否存在。當程序沒有訪問這個文件或目錄的權限的時候這個情況會發生。
如果exists()和notExists()都返回false,說明無法驗證該文件是否存在。
 

責任編輯:金賀 來源: JavaEye博客
相關推薦

2020-03-11 10:09:57

JAVA詳解classpath

2011-07-22 14:29:32

iOS 文件

2024-03-01 20:28:54

CentOS 7文件操作search

2011-08-29 09:26:57

Windows 8文件界面

2023-03-27 16:44:23

2009-12-07 17:51:39

2011-10-27 14:15:05

Java 7

2011-02-15 09:49:31

Windows 7文件訪問

2012-05-15 10:05:56

WP7 下載進度

2010-08-17 14:51:05

IE8兼容性

2011-07-21 11:25:13

iOS 窗口 事件

2011-04-01 09:43:50

Windows 7權限

2009-08-18 17:05:08

C#操作xml文件

2011-08-10 11:12:33

iPhone文件

2009-12-08 18:27:14

Windows 7操作

2009-12-01 09:23:57

Windows 7文件共享

2009-01-11 09:52:14

Windows 7微軟補丁

2009-12-25 14:46:53

Windows 7文件關聯

2024-08-27 12:18:23

函數Python

2009-09-11 08:18:29

Windows 7文件管理
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美色图另类 | 日韩av福利在线观看 | 亚洲人成一区二区三区性色 | 91精品亚洲 | 国产成人久久精品一区二区三区 | 亚洲aⅴ | 秋霞性生活 | 久久y| 伊人久久大香线 | 天天干天天谢 | 国内精品99 | 91视频在线看 | 国产区在线观看 | 亚洲高清网 | 久久成人av电影 | 性色av一区 | 成人特级毛片 | 欧美日韩一二三区 | 久久久久久久久国产 | 完全免费av在线 | 羞羞视频网 | 亚洲成人在线网 | 亚洲成人黄色 | 欧美国产一区二区 | 欧美男人的天堂 | 最近日韩中文字幕 | 亚洲网在线 | 国产电影一区二区在线观看 | 亚洲免费久久久 | 亚洲黄色在线 | 日韩成人免费在线视频 | 亚洲国产成人精品久久久国产成人一区 | 91精品国产综合久久久亚洲 | 国产精品久久久久无码av | 欧产日产国产精品视频 | 自拍偷拍小视频 | 97国产超碰 | 日日夜夜天天 | 国产精品一区视频 | 久久精品a| 精品国产精品国产偷麻豆 |