Java 中使用递归遍历文件目录

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());
                    }
                }
            }

        }
    }

}

猜你喜欢

转载自blog.csdn.net/wagnteng/article/details/60869581