【发布时间】:2016-10-04 07:57:05
【问题描述】:
我不太确定如何为这个问题命名,但我遇到了一些我不太了解的错误。
我有一种方法可以递归地在根目录的标记为“计算”的子目录中搜索其文件内容。当我打印到控制台时它似乎工作。但是,当我尝试将这些文件添加到文件列表时,它似乎不起作用,大小为 0...
如何将这些文件添加到 List 或 File[] 或任何类型的数据结构中以便我可以处理它们?
这是我的代码:
public static List<File> walkDirectory(String path) {
List<File> fileList = new ArrayList<File>();
File root = new File(path);
File[] list = root.listFiles();
if (list == null) return null;
for (File f : list) {
if (f.isDirectory()) {
walkDirectory(f.getAbsolutePath());
}
else if (f.getParentFile().getName().contains("calculation")) {
fileList.add( f ); // does not work...
System.out.println("File: " + f.getAbsoluteFile());
}
}
return fileList;
}
public static void main(String[] args) {
System.out.println(FileWalker.walkDirectory("/path/to/root/directory").size()); // size is 0
}
【问题讨论】:
标签: java file recursion data-structures filefilter