用递归遍历所有目录文件

概述

有个需求要求对文件中的所有目录进行递归查找

demo

如下图,首先获取到根目录所有数据,如果文件类型是目录,获取目录路径,以这个目录路径为新根目录路径,获取新根目录路径下的所有数据,如果文件类型是目录,获取目录路径,以这个目录路径为新根目录路径…如此反复
在这里插入图片描述

核心代码如下:
在这里插入图片描述

完整代码如下:

有这样一种情况,需要对目录下的文件和目录进行统计,为此做了一个抽象类能够方便扩展

public abstract class FieSystemPath {  
    /*遍历所有的目录及所有的文件,计算目录数及文件数*/
    protected String path;
    protected ArrayList<File> filesList;

    public FieSystemPath(String path){
        this.path = path;
    }

    public abstract  ArrayList<File> search();
    public abstract  long countNumOfFiles();
    public abstract  long countSizeOfFiels();

    public String getPath(){
        return path;
    }

}
public class FilePath extends FieSystemPath{

    public FilePath(String path) {
        super(path);
        super.filesList = new ArrayList<>();
    }

    @Override
    public ArrayList<File> search() {

        File[] files = new File(path).listFiles();

        for (int i = 0; i < files.length; i++) {

            if (files[i].isDirectory()){
                path = files[i].getPath();
                search();
            }else {
                filesList.add(files[i]);
            }
        }
        return filesList;

    }

    @Override
    public long countNumOfFiles() {

        return filesList.size();
    }

    @Override
    public long countSizeOfFiels() {
        long countNum = 0;
        for (File file:filesList) {
            countNum += file.length();
        }
        return countNum;
    }

    public static void main(String[] args) {

        FilePath filePath = new FilePath("D:/work/learn/book");
        ArrayList<File> search = filePath.search();
        search.stream().forEach(System.out::println);
        long countNumOfFiles = filePath.countNumOfFiles();
        System.out.println("countNumOfFiles:"+countNumOfFiles);
        long countSizeOfFiels = filePath.countSizeOfFiels();
        System.out.println("countSizeOfFiels:"+countSizeOfFiels);

    }

}

有人会问,目录接口调用的结束条件是什么,由于目录调用条件是有for循环的,对于整体来说,第一个循环在遍历的时候,获取到新目录路径,会调用search函数,遍历新路径下的数据,这时候已经没有新的路径了,当第二个循环遍历完了之后,就会返回第一个循环,继续往下找,如此反复,当第一个循环的i==file.length的时候,整个函数就结束了,所以结束条件隐含在了for循环中
在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值