您好,登錄后才能下訂單哦!
本篇內(nèi)容主要講解“Java怎么遍歷文件夾”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學(xué)習(xí)“Java怎么遍歷文件夾”吧!
/** 遍歷文件夾 */
public class TraversalFolder { /** * 深度優(yōu)先遍歷文件夾 * <p> * 要點:使用遞歸的方式來實現(xiàn)。 * * [@param](https://my.oschina.net/u/2303379) topFile * [@param](https://my.oschina.net/u/2303379) orderedList */ public static void depthFirstSearch(File topFile, ArrayList<File> orderedList) { if (null != topFile) { if (topFile.isDirectory()) { File[] files = topFile.listFiles(); for (File file : files) { if (file.isDirectory()) { depthFirstSearch(file, orderedList); } else { orderedList.add(file); } } } else { orderedList.add(topFile); } } } /** * 廣度優(yōu)先遍歷文件夾 * <p> * 要點:利用棧的先進后出的特點來實現(xiàn)。 * * [@param](https://my.oschina.net/u/2303379) topFile * [@param](https://my.oschina.net/u/2303379) orderedList * [@param](https://my.oschina.net/u/2303379) maxNum */ public static void breadthFirstSearch(File topFile, ArrayList<File> orderedList, int maxNum) { if (null != topFile) { LinkedBlockingQueue<File> queue = new LinkedBlockingQueue<File>(maxNum); queue.offer(topFile); while (!queue.isEmpty()) { File file = queue.poll(); if (file.isDirectory()) { File[] files = file.listFiles(); for (File f : files) { if (f.isDirectory()) { queue.offer(f); } else { orderedList.add(f); } } } else { orderedList.add(file); } } } } public static void main(String[] args) { String path = "C:\\Users\\jxn\\Desktop\\新建文件夾(3)"; File topFile = new File(path); ArrayList<File> orderedList = new ArrayList<>(); // depthFirstSearch(topFile,orderedList); breadthFirstSearch(topFile, orderedList, 100); orderedList.stream().forEach((x) -> { System.out.println(x.getAbsoluteFile()); }); }
}
到此,相信大家對“Java怎么遍歷文件夾”有了更深的了解,不妨來實際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進入相關(guān)頻道進行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。