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