JAVA基础—递归的使用

java中我们很多时候为了得到最终的结果需要一直做某件事无数次,我们可以使用for 、while的循环来完成它,但是有些时候我们不知道需要多少次循环才能结束,java中的递归可以帮助我们很方便的解决这种问题。
递归过程一般通过函数或子过程来实现。递归方法:在函数或子过程的内部,直接或者间接地调用自己的算法。
例如,计算数学中的阶乘问题可以采用这种方法,我们想要得到一个文件夹下的所有文件时我们可以使用递归。
详细代码如下:

/**
 * 使用递归遍历一个文件夹下所有的文件
 */
import java.io.File;

public class FileGet {
    public static void main(String[] args) {
        //导入文件
        File file =new File("/home/z/文档/张振宇");
        //建立目录数组
        File[] names=file.listFiles();
        //使用方法获取所有文件
        getFile(names);
    }
    public static void getFile(File[] file)
    {
        //判断文件名数组非空
        if(file!=null){
            for(File names:file)
            {
                //判断文件名非空
                if(names.getPath()!=null){
                    //当文件名表示的是文件时输出
                    if(names.isFile())
                    {
                        System.out.println(names.getName());
                    }
                    //当文件名为文件夹时继续调用方法
                    else
                    {
                        getFile(names.listFiles());
                    }
                }
            }
        }
    }
}

你可能感兴趣的:(java基础)