java递归实现统计某一目录下文件的个数
需求:统计某一个指定目录下文件的个数,文件夹不统计在内。
分析递归退出的条件:
- 该文件确实是一个文件而不是文件夹
- 该文件夹是一个空目录
除了上述两个退出条件之后其他情况下都要不断的进行递归,于是就有了以下的设计实现
/**
*
* 递归统计该目录下的文件个数(只统计文件,如果目录下还有目录一直往下查找)
* @param directory,这里的参数也可以换成string类型,直接给出文件夹路径
* @return
*/
private static int countFileNumber(File directory){
int n = 0;
if (!directory.isDirectory()){
return 1;
}
File[] files = directory.listFiles();
for(File direc : files){
n+=countFileNumber(direc);
}
return n;
}
测试:我测试统计了我的D盘下的ProgramFiles文件夹,运行时间较长,大概一分钟不到,统计出了62266个文件,当然这个我无法考证,因为实在文件太多了,所以我又自己新建了一个目录,里面创建了一些文件夹和文件,目录的结构如下:
测试结果:统计到的个数确实为3