java非递归遍历文件夹

本文采用非递归方式遍历指定目录下的所有内容。
  提到文件夹的遍历,首先想到的就是递归,若找到文件,则对文件进行相应的操作。若为文件夹,则继续调用自身方法。
  但递归调用存在一个问题,若文件的层级过深,有可能会引发栈溢出(具体栈溢出的相关知识可自行百度,这里不再详细介绍)。因此,采取非递归的方式,可以有效避免这种情况的发生。
  本次采取的思路是利用LinkedList集合存储当前目录下的所有文件与文件夹,并对集合进行循环访问。
  若为文件夹,则将该文件夹内的所有文件与文件夹添加到集合中,若为文件,则直接操作文件。每次循环结束后,移除集合的第一个元素。最终,就能达到访问所有数据的目的。
下面是完整实现代码
public class Test {
   
    public static void main(String[] args) throws Exception {
   
        // 根目录
        String rootPath = "E:\\test";
        // 存储文件夹下所有文件的url
        List<String> urls = new ArrayList();
        
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值