我的代码如下
public class FileHandler {
public static void main(String... args) {
File file = new File("C:/Users/TJF22/Desktop/Simple Network 1/alpha 15");
mapFiles(file);
}
public static HashMap<String,File[]> mapFiles(File directory){
File[] inputContents = directory.listFiles();
HashMap<String,File[]> fileMap= new HashMap<String,File[]>();
for (File content : inputContents){
if (content.isDirectory()){
File[] nestedContents = content.listFiles();
if (areAllFiles(nestedContents)){
String key = content.getPath();
fileMap.put(key,nestedContents);
} else {
mapFiles(content);
}
}
}
return fileMap;
}
public static boolean areAllFiles(File[] directory){
for (File files : directory){
if (!files.isFile()){
return false;
}
}
return true;
}
我想要做的是能够递归地遍历给定的输入文件目录以及该输入目录中包含的文件:
-如果文件是一个目录,并且该目录中的所有内容都是文件,则将目录名作为键与其中的文件名(作为值)关联起来,并存储到 fileMap
-如果该文件是一个目录并且其中包含其他目录,则继续前进,直到找到其中仅包含文件的目录
-如果该文件是文件,则忽略它
但我的问题是,当我返回 fileMap、HashMap 时,我得到一个空的 HashMap,因为由于某种原因,我存储的键值对没有被保存。有什么帮助吗?
最佳答案
您需要跟踪现有的 HashMap,而不是每次重新调用 mapFiles
时都重新创建映射。
public static HashMap<String,File[]> mapFiles(File directory){
HashMap<String,File[]> fileMap = new HashMap<String,File[]>();
fileMap = mapFiles_Recursive(directory, fileMap);
return fileMap;
}
private static HashMap<String,File[]> mapFiles_Recursive(File directory, HashMap<String,File[]> fileMap) {
File[] inputContents = directory.listFiles();
for (File content : inputContents){
if (content.isDirectory()){
File[] nestedContents = content.listFiles();
if (areAllFiles(nestedContents)){
String key = content.getPath();
fileMap.put(key,nestedContents);
} else {
mapFiles(content, fileMap);
}
}
}
return fileMap;
}
关于java - 递归堆栈不保存 HashMap 中的更改,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34078320/