本篇内容主要讲解“Java怎么遍历文件夹”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java怎么遍历文件夹”吧!
/** 遍历文件夹 */
public class TraversalFolder {
/**
* 深度优先遍历文件夹
* <p>
* 要点:使用递归的方式来实现。
*
* [@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);
}
}
}
/**
* 广度优先遍历文件夹
* <p>
* 要点:利用栈的先进后出的特点来实现。
*
* [@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怎么遍历文件夹”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。
原文链接:https://my.oschina.net/u/1399755/blog/1829217