我有一个实现可以在String中找到重复的字符:

Map<Character, Integer> charMap = new HashMap<>();
for (int i = 0; i < word.length(); i++) {
    Character ch = word.charAt(i);
    if (charMap.containsKey(ch)) {
        charMap.put(ch, charMap.get(ch) + 1);
    } else {
        charMap.put(ch, 1);
    }
}

我想知道是否可以将此实现转换为Java 8Stream实现。做这样的事情:
Map<Character, Integer> charMap = new HashMap<>();

然后将String word转换为字符的List:
List<Character> chars = word.chars()
        .mapToObj(i -> (char) i)
        .collect(Collectors.toList());

现在要做类似的事情:
chars.stream()
        .filter(e -> charMap.containsKey(e))...

最佳答案

您可以使用此:

        Map<Character, Integer> charMap = new HashMap<>();
        String word = "acbczabcd";
        word.chars().forEach(ch -> charMap.put((char) ch, charMap.getOrDefault((char) ch, 0) + 1));

,带有mapToObj
word.chars().mapToObj(n -> (char) n).forEach(ch -> charMap.put(ch, charMap.getOrDefault(ch, 0) + 1));

10-05 19:33