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

本文介绍如何使用Java中的File类结合递归方法列出指定路径下的所有文件和子目录,形成目录树结构。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

听说,列出指定路径的文件件目录树,File类和递归更配哦。

在Java中,File类代表的是当前系统中的某个指定文件夹目录或文件对象。比如可以通过 File file1 = new File("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:/音乐/周杰伦");
}
}

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

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



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值