插入到Map中的值不会保留在循环的第二个循环中

时间:2016-01-13 19:21:19

标签: java dictionary hashmap

下面的功能将具有给定扩展名的所有文件从rootDirectory复制到给定目标。当文件的名称不同时,它运行良好,但是当有两个具有相同名称的文件时(请参阅recurvive调用 - 它可以在子目录中),它不会做它应该做的事情。如果有更多具有相同名称的文件,则应复制这两个文件并重命名第二个文件(将_1,_2,...添加到其名称中)。

我看到我正在使用的地图可能存在问题 - 每次复制文件时,我都想保存它的名称并添加计数器,计算它被复制的次数(所以适当的号码可以添加到其名称)。你能帮我解决一下这个问题吗?

void copy(File rootDirectory, String destination, String fileExtension) {
    File destFile = new File(destination);
    HashMap<String, Integer> counter = new HashMap<>();
    for (File file : rootDirectory.listFiles()) {
        try {
            if (file.isDirectory()) { copy(file, destination, fileExtension);
            } else if (getExtension(file.getPath().toLowerCase()).equals(fileExtension.toLowerCase())) { 
                if (!destFile.exists()) { destFile.mkdirs();}
                String fileName = file.getName();
                if(counter.containsKey(fileName)){  // <<-- IS NEVER TRUE 
                    int count = counter.get(fileName);
                    count++;
                    counter.put(fileName, count);
                    int i = fileName.contains(".") ? fileName.lastIndexOf('.') : fileName.length();
                    fileName = fileName.substring(0, i) + "_" + count + fileName.substring(i);
                } else{ counter.put(fileName, 0);
                }
                Files.copy(file.toPath(), Paths.get(destination + "\\" + fileName), StandardCopyOption.REPLACE_EXISTING);
            }
        } catch (IOException e) {
            //...
        }
    }
} 

1 个答案:

答案 0 :(得分:5)

您正在使用递归。换句话说,你总是从一个新的空地图开始。将地图放在方法之外,这将解决您的问题。