java遍历目录下的包括子目录下的所有文件
生活随笔
收集整理的這篇文章主要介紹了
java遍历目录下的包括子目录下的所有文件
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
在java中遍歷一個文件夾里邊的所有文件,可以有兩種方式:
?
? ? 一、遞歸遍歷,通常也是開發者第一時間能想到的方法,遞歸遍歷的優點是:實現起來相對簡單,代碼量相對較少,執行效率較高,缺點是:比較吃內存,對硬件要求較高;具體算法如下:
二、非遞歸遍歷,遞歸遍歷的話是很容易理解的,但是非遞歸遍歷的話估計思路不太容易上來,我當時也苦思良久,發現java有個一個LinkedList這玩意,字面上也大概知道,這個是用來保存一個鏈接文件的列表,有這個的話就好辦了,具體思路是這樣:遍歷一個文件夾的時候,如果是文件夾,就添加到linkedlist里去,如果是文件則列出;這樣該目錄的文件和文件夾就遍歷完畢了,文件夾全部被保存到linkedlist里;所以剩下的就是遍歷linkedlist里邊的文件夾的文件,遍歷方式同上邊的操作一致,如果是文件夾就添加到linkedlist里邊(Ps:遍歷過程中的linkedlist始終是同一個list),當然每次從列表取出一個文件夾之后需要從列表中刪除該文件夾,這里采用linkedlist.removeFirst()來讀取,這樣是每次讀取列表的第一個元素并將其從列表剔除。這樣只要遍歷到linkedlist的狀態是isEmty的時候就說明遍歷完畢了。算法如下:
/*** 非遞歸遍歷* @param file* @return*/public static LinkedList<File> GetDirectory(String path) {File file = new File(path);LinkedList<File> Dirlist = new LinkedList<File>(); // 保存待遍歷文件夾的列表LinkedList<File> fileList = new LinkedList<File>();GetOneDir(file, Dirlist, fileList);// 調用遍歷文件夾根目錄文件的方法File tmp;while (!Dirlist.isEmpty()) {tmp = (File) Dirlist.removeFirst();// 從文件夾列表中刪除第一個文件夾,并返回該文件夾賦給tmp變量// 遍歷這個文件夾下的所有文件,并把GetOneDir(tmp, Dirlist, fileList);}return fileList;}// 遍歷指定文件夾根目錄下的文件private static void GetOneDir(File file, LinkedList<File> Dirlist,LinkedList<File> fileList) {// 每個文件夾遍歷都會調用該方法File[] files = file.listFiles();if (files == null || files.length == 0) {return;}for (File f : files) {if (f.isDirectory()) {Dirlist.add(f);} else {// 這里列出當前文件夾根目錄下的所有文件,并添加到fileList列表中fileList.add(f);// System.out.println("file==>" + f);}}}?
總結
以上是生活随笔為你收集整理的java遍历目录下的包括子目录下的所有文件的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: JVM中的线程说明
- 下一篇: idea 自动导入包和自动将没用的包去除