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