Java编程获取文件列表及子文件目录的方法(非递归)
发布时间:2020-12-14 21:16:21 所属栏目:Java 来源:网络整理
导读:废话不谈,直接进入正题,理解见代码注释。 // 非递归 public ListString scanFiles(String path) { ListStringfilePaths = new ArrayListString(); LinkedListFile list = new LinkedListFile(); File dir = new File(path); File[] file = dir.listFiles()
废话不谈,直接进入正题,理解见代码注释。 // 非递归 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编程枚举类型那些事!枚举类型定义和重写枚举的方法等,如有不足之处,欢迎留言参考。感谢朋友们对本站的支持! (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |