废话不谈,直接进入正题,理解见代码注释。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
|
// 非递归
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编程获取文件列表及子文件目录的方法(非递归)的全部内容,希望对大家有所帮助。如有不足之处,欢迎留言参考。感谢朋友们对本站的支持!
原文链接:http://blog.csdn.net/u014294166/article/details/52076315#comments