Java 中使用递归遍历文件目录
上周去新浪爱彩面试,面试中遇到一个使用递归遍历文件目录的题目,由于对文件的操作不熟悉,大概的思路说出来了,但还是没写出来。回来后就查了一下资料,感觉也不是很难,下面就分享一下如何处理。
解题思路
- 从电脑中获取文件目录,建立函数对其遍历
- 在这个函数中需要对该目录中的每个文件进行判断,如果文件还是目录,则调用函数本身继续对其进行遍历,如果文件不是目录,则直接输出文件名。
代码展示
import java.io.File;
public class FileTraversal {
public static void main(String[] args) {
// TODO Auto-generated method stub
File file=new File("D:");
listAll(file);
}
/**
* 传入需要遍历的文件
* @param file
*/
public static void listAll(File file){
if(file.exists()){//先判断文件是否存在
File[] files=file.listFiles();//获取指定目录下当前的所有文件夹或者文件对象
if(files!=null && files.length>0){//判断是否文件下为空
for (int i = 0; i < files.length; i++) {//对文件进行遍历
if(files[i].exists()&&files[i].isDirectory()){//判断文件是否是文件夹,如果是文件夹则继续调用listAll进行递归遍历
listAll(files[i]);
}else {//如果不是文件夹,则输出文件名
System.out.println(files[i].getName());
}
}
}
}
}
}