使用 Java 8 和 lambdas,很容易将集合作为流进行迭代,并且使用并行流同样容易。文档中的两个示例,第二个使用 parallelStream:
myShapesCollection.stream()
.filter(e -> e.getColor() == Color.RED)
.forEach(e -> System.out.println(e.getName()));
myShapesCollection.parallelStream() // <-- This one uses parallel
.filter(e -> e.getColor() == Color.RED)
.forEach(e -> System.out.println(e.getName()));
只要我不关心顺序,使用并行是否总是有益的?人们会认为将工作分配到更多内核上会更快。
还有其他考虑吗?什么时候应该使用并行流,什么时候应该使用非并行?
(问这个问题是为了引发关于如何以及何时使用并行流的讨论,而不是因为我认为总是使用它们是一个好主意。)