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());
}
}
}
}
}
}