【判空】判断文件夹里面有没有文件,递归查询,java代码

《【判空】判断文件夹里面有没有文件,递归查询,java代码》

思路:

进入根目录,遍历所有文件,如果发现有文件夹就进入再遍历该目录,以此类推,在遍历过程中,发现任一目录有非文件夹文件就返回true,然后一经返现有文件就不会再进入任何目录,每一层直接返回true。

递归调用算法如下:

public static Boolean hasFile(File file) {

    boolean hasFile = false;
    File[] listFiles = file.listFiles();
    for (File file1 : listFiles) {
        if (file1.isDirectory() && hasFile == false) {
            hasFile = hasFile(file1);   // 如果是目录且没有发现有文件,回调自身继续查询
        }else{
            return true;
        }
    }
    return hasFile;
}

完整测试如下

package com.xiong.test.file;

import java.io.File;

/**
 * @author Tan
 * @version V1.0
 * @description: FileTest
 * @date 2019/10/10
 */
public class FileTest {

    public static void main(String[] args) {
        String path = "C:\\files";
        File file = new File(path);

        if (hasFile(file)) {
            System.out.println("文件夹下有文件");
        } else {
            System.out.println("文件夹下没有文件");

        }
    }


    public static Boolean hasFile(File file) {

        boolean hasFile = false;
        File[] listFiles = file.listFiles();
        for (File file1 : listFiles) {
            if (file1.isDirectory() && hasFile == false) {
                hasFile = hasFile(file1);   // 如果是目录且没有发现有文件,回调自身继续查询
            }else{
                return true;
            }
        }
        return hasFile;
    }
}

    原文作者:cy谭
    原文地址: https://blog.csdn.net/zhan107876/article/details/102499973
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞