递归统计某目录下的所有文件名
1.输出案例
C:\Users\DELL\Desktop\12\23\cutcamera.png
C:\Users\DELL\Desktop\12\IO流.docx
2.代码实现
package RecurrenceFile;
import java.io.File;
import java.util.ArrayList;
import java.util.List;
public class RecurrenceFile {
public static void main(String[] args) {
//要查询的路径
String path = "C:\\Users\\DELL\\Desktop\\12";
// 新建一个集合,用于存储
List<String> fnames = new ArrayList<String>(500);
// 调用,传参
findFiles(path, fnames);
// 遍历数组
for (String name : fnames) {
System.out.println(name);
}
}
/*
* path 传入查找的路径
* List<String> fnames; 通过引用接收返回值
*/
public static void findFiles(String path, List<String> fnames) {
if (path != null) {
File file = new File(path);
if (file.exists() && file.isDirectory()) {
File[] files = file.listFiles();
for (File f : files) {
if (f.isDirectory()) {
// 如果是文件夹,调用自身,递归查找
findFiles(f.getPath(), fnames);
} else {
// 如果是文件,加到数组中
fnames.add(f.getPath());
}
/* exists()测试此抽象路径名表示的文件或目录是否存在,返回值位布尔型
* isDirectory()是检查一个对象是否是文件夹,返回值位布尔型
* list()方法是返回某个目录下的所有文件和目录的文件名,返回的是String数组
* listFiles()方法是返回某个目录下所有文件和目录的绝对路径,返回的是File数组
*/
}
}
}
}
}