我正在使用一个带有三个参数的简单reduce方法。身份,累加器和组合器。 这是我的代码......
Integer ageSumComb = persons
.stream()
.reduce(0,
(sum, p) -> {
System.out.println("Accumulator: Sum= "+ sum + " Person= " + p);
return sum += p.age;
},
(sum1, sum2) -> {
System.out.format("Combiner: Sum1= " + sum1 + " Sum2= "+ sum2);
return sum1 + sum2;
但是发生的事情是Combiner没有被执行。我没有得到这背后的原因。 这是我的输出..
Accumulator: Sum= 0 Person= Max
Accumulator: Sum= 18 Person= Peter
Accumulator: Sum= 41 Person= Pamela
Accumulator: Sum= 64 Person= David
Accumulator: Sum= 76 Person= Pam
但是,没有编译错误,没有异常,我的输出完全正确,与我的预期相同。但是没有理解为什么合并器没有被执行。
答案 0 :(得分:7)
仅针对并行流执行Combiner。
答案 1 :(得分:0)
如果您要使用合并器,则需要使用parallelStream
代替stream