圖解 Java IO : 一、File源碼
記得Java源碼是從集合類開始看的,寫了一係列集合相關的文章,受到不錯的評價。感謝各位讀者。我依舊會讀到老寫到老,並生動形象的寫出來心得體會。這次依舊是圖解Java IO。
Java IO – File的要點,應該是
1、跨平台問題的解決
2、文件的安全
3、文件的檢索方法
一、代碼小引入
代請看一個簡單的小demo:(ps:開源項目java-core-learning地址:https://github.com/JeffLi1993)
import java.io.File; import java.util.Arrays; /* * Copyright [2015] [Jeff Lee] * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * https://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * @author Jeff Lee * @since 2015-7-13 07:58:56 * 列出目錄並排序 */ public class DirListT { public static void main(String[] args) { // 獲取當前目錄 File path = new File(".");// .表示當前目錄 // 文件路徑名數組 String list[] = path.list(); // 對String文件名進行排序 Arrays.sort(list,String.CASE_INSENSITIVE_ORDER); // 打印 for(String dirItem : list) System.out.println(dirItem); } }
在eclipse中,右鍵run一下,可以得到如下的結果:
如圖,很容易注意到了,其目錄下的名字排序按字母並打印了。
先回顧下API知識吧,
首先構造函數 public File(String pathname)
通過將給定路徑名字符串轉換為抽象路徑名來創建一個新
File
實例。如果給定字符串是空字符串,那麼結果是空抽象路徑名。
- 參數:
pathname
– 路徑名字符串- 拋出:
NullPointerException
– 如果pathname
參數為null
- 二者,File實現了Comparator接口,以便對FileName進行排序。
static Comparator<String>
CASE_INSENSITIVE_ORDER
一個對String
對象進行排序的 Comparator,作用與compareToIgnoreCase
相同。
三者, path.list()為什麼會返回String[] filenams的數組呢?怎麼不是List呢?
自問自答:這時候,我們應該去看看ArrayList的實現,ArrayList其實是動態的數組實現。動態,動態的弊端就是效率低。此時,返回一個固定的數組,而不是一個靈活的類容器,因為其目錄元素是固定的。下麵是ArrayList和數組Array的比較:
二、深入理解源碼
File,File究竟是怎麼構成的。順著源碼,知道了File有幾個重要的屬性:
1、static private FileSystem fs
FileSystem : 對本地文件係統的抽象
2、String path 文件路徑名
3、內聯枚舉類
PathStatus 地址是否合法 ENUM類 private static enum PathStatus { INVALID, CHECKED };
4、prefixLength 前綴長度
- 如下,給出File相關核心的UML圖:
其實操作的是 FileSystem : 對本地文件係統的抽象,真正操作的是 FileSytem的派生類。通過源碼Ctrl+T發現如下:Win下操作的是Win32FileSystem 和 WinNTFileSystem類。看來真正通過jvm,native調用係統的File是他們。
那Linux呢?因此,下了個Linux版本的JDK,解壓,找到rt.jar。然後java/io目錄中,找到了UnixFileSystem類。真相大白了!
所以可以小結File操作源碼這樣調用的:中間不同JDK,其實是不同的類調用本機native方法。
三、小demo再來一發
File 其實和我們在係統中看的的文件一樣。就像我們右鍵,屬性。可以看到很多File的信息。Java File也有。下麵是一個文件的相關方法詳情:
import java.io.File; /* * Copyright [2015] [Jeff Lee] * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * https://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * @author Jeff Lee * @since 2015-7-13 10:06:28 * File方法詳細使用 */ public class FileMethodsT { private static void fileData(File f) { System.out.println( " 絕對路徑:" + f.getAbsolutePath() + "\n 可讀:" + f.canRead() + "\n 可寫:" + f.canWrite() + "\n 文件名:" + f.getName() + "\n 上級目錄:" + f.getParent() + "\n 相對地址:" + f.getPath() + "\n 長度:" + f.length() + "\n 最近修改時間:" + f.lastModified() ); if(f.isFile()) System.out.println(" 是一個文件"); else if(f.isDirectory()) System.out.println(" 是一個目錄"); } public static void main(String[] args) { // 獲取src目錄 File file = new File("src"); // file詳細操作 fileData(file); } }
在eclipse中,右鍵run一下,可以得到如下的結果:大家應該都明白了吧。
文件如何過濾呢?
以後獨立講吧,過濾涉及Fiter類。
四、總結
1、看源碼很簡單,看數據結構。看如何調用。或者是有些設計模式
2、學東西,學一點一點深一點。太深不好,一點就夠了
3、泥瓦匠學習的代碼都在github上(同步osc git),歡迎大家點star,提意見,一起進步。地址:https://github.com/JeffLi1993
最後更新:2017-05-22 15:33:14