递归

使用递归来遍历一个路径下的一个文件夹下的所有的文件和文件夹

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为止

 

 

posted @ 2019-04-20 16:49  T&K  阅读(145)  评论(0编辑  收藏  举报