递归
使用递归来遍历一个路径下的一个文件夹下的所有的文件和文件夹
package com.jp_digui_01; import java.io.File; public class Demo2 { public static void main(String[] args) { //列出一个文件夹下的所有的子文件夹以及子文件 File file=new File("J:\\eclipse\\数据\\chapter12\\src"); showList(file); } public static void showList(File file) { if(file.isDirectory()) { File[] listFiles = file.listFiles(); for(File f:listFiles) { if(f.isFile()) { System.out.println("文件: "+f.getName()); }else if(f.isDirectory()) { //这里循环的f是文件夹对象 showList(f);//这里用的就是递归 } } } System.out.println("文件夹: "+file.getName()); } }
在main方法里,将File路径下的src文件夹封装成为一个对象然后调用showList方法
public static void main(String[] args) { //列出一个文件夹下的所有的子文件夹以及子文件 File file=new File("J:\\eclipse\\数据\\chapter12\\src"); showList(file); }
之后在show方法里,判断调用的是否是文件夹,如果是则进入if语句,如果不是则输出(一般情况不会是一个文件,只可能调用文件夹,因为题目中说的是遍历一个路径文件夹下的所有文件或文件夹,所以不会造成将文件输出为文件夹的情况)
if(file.isDirectory()) { } System.out.println("文件夹: "+file.getName());
之后就开始循环判断此文件夹下的所有的东西是否为文件,如果是,则输出文件,如果不是则运用递归重新调用此方法(注意:重新调用的方法可以理解为将重新检索下一个文件夹里的东西,重新调用一次判断循环,但是也要注意最后的文件夹的输出也是随着递归进行的,在思考时不能漏掉)
File[] listFiles = file.listFiles(); for(File f:listFiles) { if(f.isFile()) { System.out.println("文件: "+f.getName()); }else if(f.isDirectory()) { //这里循环的f是文件夹对象 showList(f);//这里用的就是递归 } }
最终检索到文件时开始结束该方法,一层一层往上结束方法,结束的时候如果有文件夹,则会输出文件夹的名字
输出结果:
逻辑图:
当循环到testConstructor.java时,开始循环结束for循环,从testConstructor.java开始向外结束循环,并且输出文件或者是文件夹,最终输出到src为止