写在前面: 递归的重点在于大问题化小问题 以及 找到方法调用的终止条件
遍历文件夹
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 void show(File file,int count){
// 1.将文件直系目录下内容 封装成file数组
File[] list = file.listFiles();
// 2.不管当前file是文件还是文件名 ,先打印出来
printFileName(count,file);
// 3.当前是文件,则终止 当前是文件夹, 那么之后的文件和文件夹都要空一个tab
count++;
if (list.length==0||list==null){
return;
}
// 4.遍历这个file数组, 如果是文件直接打印, 如果是文件夹,重新执行show方法逻辑
for (File f : list) {
if (f.isFile()){
printFileName(count,f);
}else{
show(f,count);
}
}
}
}
最终效果:
统计文件类型
输入文件夹, 统计文件中所有类型的个数
当遇到计数一类的问题时, 考虑使用HashMap
思路: 遍历文件夹内容, 如果是文件按照 "." 分割, 存储到hashmap中
1.将传入的文件或文件夹封装成文件数组
2.遍历这个文件数组
3.如果是文件, 将文件名以. 分割,获取后缀
4.判断hashmap中有没有这个后缀, 没有添加, 有则在原来的数量基础上+1
5.如果不是文件,则是文件夹, 按照cout方法逻辑再走一遍
public class FileDemo {
static HashMap<String,Integer> fileCount= new HashMap<>();
public static void main(String[] args) {
File file = new File("D:\\Pro\\File\\Fu\\a");
count(file);
System.out.println(fileCount);
}
public static void count(File file){
// 1.将传入的文件或文件夹封装成文件数组
File[] list = file.listFiles();
if (list.length==0||list==null){
return;
}
// 2.遍历这个文件数组
for (File f : list) {
if (f.isFile()){
// 3.如果是文件, 将文件名以. 分割,获取后缀
int i = f.getName().lastIndexOf(".") + 1;
String sub = f.getName().substring(i);
// 4.判断hashmap中有没有这个后缀, 没有添加, 有则在原来的数量基础上+1
if (fileCount.containsKey(sub)){
fileCount.put(sub,fileCount.get(sub)+1);
}else {
fileCount.put(sub,1);
}
// 5.如果不是文件,则是文件夹, 按照cout方法逻辑再走一遍
}else {
count(f);
}
}
}
}
最终效果: