时间:2021-05-20
废话不谈,直接进入正题,理解见代码注释。
// 非递归 public List<String> scanFiles(String path) { List<String>filePaths = new ArrayList<String>(); LinkedList<File> list = new LinkedList<File>(); File dir = new File(path); File[] file = dir.listFiles(); for (int i = 0; i < file.length; i++) { if (file[i].isDirectory()) { // 把第一层的目录,全部放入链表 list.add(file[i]); } filePaths.add(file[i].getAbsolutePath()); } // 循环遍历链表 while (!list.isEmpty()) { // 把链表的第一个记录删除 File tmp = list.removeFirst(); // 如果删除的目录是一个路径的话 if (tmp.isDirectory()) { // 列出这个目录下的文件到数组中 file = tmp.listFiles(); if (file == null) {// 空目录 continue; } // 遍历文件数组 for (int i = 0; i < file.length; ++i) { if (file[i].isDirectory()) { // 如果遍历到的是目录,则将继续被加入链表 list.add(file[i]); } filePaths.add(file[i].getAbsolutePath()); } } } return filePaths; }以上就是本文关于Java编程获取文件列表及子文件目录的方法(非递归)的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站:Java编程子类能否重写父类的静态方法探索、java编程枚举类型那些事!枚举类型定义和重写枚举的方法等,如有不足之处,欢迎留言参考。感谢朋友们对本站的支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
java递归读取目录下的所有文件(包含子目录下的所有文件)大概思路如下:通过file.listFiles()方法获取目录下的所有文件(包含子目录下的所有文件),
下面GetFileList方法负责列出指定目录的文件列表。//////获取文件列表///privatevoidGetFileList(){stringstrCu
最近在学C#的文件系统,发现C#的文件系统貌似比java的东西少一点,居然连删除目录都直接做好封装了,想到学java的时候还要自己写递归删除,好像没写过非递归的
代码思路:想要循环遍历文件夹下所有子文件夹,就要用到递归。首先判断路径是否存在: 是:获取文件 判断是否文件夹: 是:调用自身,继续获取子文件
本文实例讲述了java实现递归文件列表的方法。分享给大家供大家参考。具体如下:FileListing.java如下:importjava.util.*;impo