思路:
进入根目录,遍历所有文件,如果发现有文件夹就进入再遍历该目录,以此类推,在遍历过程中,发现任一目录有非文件夹文件就返回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;
}
}
版权声明:本文为zhan107876原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。