否。累加器不应修改其自变量。它接受两个值并产生一个新值。如果要在累积过程中使用突变(例如,将字符串累积到StringBuffer中而不是进行串联),请使用
Stream.collect()专为此目的而设计的。
这是一个代码示例,如果您尝试这样做会产生错误的答案。假设您要对假设的MutableInteger类进行加法:
// Don't do thisMutableInteger result = stream.reduce(new MutableInteger(0), (a,b) -> a.add(b.get()));
得出错误答案的原因之一是,如果我们并行拆分计算,则现在两个计算共享相同的可变起始值。注意:
a + b + c + d= 0 + a + b + 0 + c + d // 0 denotes identity= (0 + a + b) + (0 + c + d) // associativity
因此我们可以自由拆分流,计算和的
0 + a + b和
0 + c +d,然后将结果相加。但是,如果它们共享相同的标识值,并且由于其中一项计算而导致该值发生了变异,则其他计算可能会从错误的值开始。
(还要注意,如果实现值得,即使对于顺序计算,也可以允许该实现执行此操作。)



