并行流、收集器和线程安全
请参阅下面的简单示例,该示例计算列表中每个单词的出现次数:
Stream<String> words = Stream.of("a", "b", "a", "c");
Map<String, Integer> wordsCount = words.collect(toMap(s -> s, s -> 1,
(i, j) -> i + j));
最后,是 。wordsCount
{a=2, b=1, c=1}
但是我的流非常大,我想并行化工作,所以我写道:
Map<String, Integer> wordsCount = words.parallel()
.collect(toMap(s -> s, s -> 1,
(i, j) -> i + j));
但是我注意到这很简单,所以我想知道我是否需要显式请求并发映射以确保线程安全:wordsCount
HashMap
Map<String, Integer> wordsCount = words.parallel()
.collect(toConcurrentMap(s -> s, s -> 1,
(i, j) -> i + j));
非并发收集器是否可以安全地与并行流一起使用,或者从并行流收集时是否应仅使用并发版本?