写在前面: 递归的重点在于大问题化小问题 以及 找到方法调用的终止条件
遍历文件夹
File类所提供的方法listFiles()只能找到直系成员, 并不能找到文件下的所有子文件和子文件夹
当考虑使用递归时, 考虑到的终止条件是: 如果是文件,直接返回文件名, 如果是文件夹, 通过使用listFiles()找到并打印文件夹中的内容, 并调用自身方法, 重新执行这个逻辑
1.将文件直系目录下内容 封装成file数组
2.不管当前file是文件还是文件名 ,先打印出来
3.当前是文件,则终止 当前是文件夹, 那么之后的文件和文件夹都要空一个tab
4.遍历这个file数组, 如果是文件直接打印, 如果是文件夹,重新执行show方法逻辑
public class Directory {
public static void main(String[] args) {
File file = new File("D:\\Pro\\File\\FU");
show(file,0);
}
public static void printFileName(int num,File file) {
//for循环打印num个制表符tab(java中用"\t"表示),不带换行
for (int i = 0; i < num; i++) {
System.out.print("\t");
}
//打印File对象名称,前面拼接|-,需要换行
System.out.println("|-"+file.getName());
}
public static v