Java 8 Stream - Reduce函数的组合器没有被执行

时间:2016-12-01 12:24:38

标签: java java-8 java-stream reduce combiners

我正在使用一个带有三个参数的简单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

但是,没有编译错误,没有异常,我的输出完全正确,与我的预期相同。但是没有理解为什么合并器没有被执行。

2 个答案:

答案 0 :(得分:7)

仅针对并行流执行Combiner。

答案 1 :(得分:0)

如果您要使用合并器,则需要使用parallelStream代替stream