以递归方式列出指定路径的文件夹目…

来源:互联网 发布:linux开机自动挂载 编辑:程序博客网 时间:2024/06/03 12:30
听说,列出指定路径的文件件目录树,File类和递归更配哦。

在Java中,File类代表的是当前系统中的某个指定文件夹目录或文件对象。比如可以通过 File file1 = newFile("F:/音乐/周杰伦");创建一个File类型的file1对象,它代表F盘的音乐文件夹里的名称为“周杰伦”的文件夹。又比如可以通过 File file2 =new File("F:/音乐/周杰伦/周杰伦 -黄金甲.mp3"); 创建一个File类型的file2对象,它代表F盘的音乐文件夹里的周杰伦文件夹里的名称为“周杰伦 -黄金甲.mp3”的文件。

递归是一种很神奇的现象。在现实生活中,我们常常会想我们在地球上,地球在太阳系,太阳系在银河系,这某种程度上就是一种递归。在数学上,阶乘和斐波那契数列是常见的递归的经典例子。而在计算机语言中,程序调用自身的行为被称为递归。

给定一个文件夹目录,通过File类提供的一系列方法,可以很容易地列出指定文件目录内的文件和文件夹。假如其中包含文件夹并且想把该文件夹内包含的文件和文件夹也列出来,甚至以此类推,把所有层次的文件和文件夹以文件夹目录树的形式列出来,就需要用到递归了,因为列出当前目录中的文件和文件夹与列出当前目录中的某个文件夹内部的文件和文件夹是完全一样的行为,所以可以通过调用自身来完成。

以递归方式列出指定路径的文件夹目录树

package month26;

import java.io.File;

public class TestRecursion {
public static void fileTree(String path) {
fileTree0(path,"");
}
public static void fileTree0(String path,String str) {
File dir = new File(path);
String[] files = dir.list();
for(int i=0; i
System.out.println(str+files[i]);
if(new File(dir+File.separator+files[i]).isDirectory()){
fileTree0(dir+File.separator+files[i],str+" ");
}
}
}
public static void main(String[] args) {
TestRecursion.fileTree("F:/音乐/周杰伦");
}
}

封装成了一个方法,并没有针对可能发生的异常做异常捕获处理。打印效果如下:

以递归方式列出指定路径的文件夹目录树



阅读全文
0 0
原创粉丝点击