【发布时间】:2014-07-02 18:18:03
【问题描述】:
我正在尝试了解新的 Java 8 Stream API。
http://docs.oracle.com/javase/tutorial/collections/streams/reduction.html
我找到了使用 collect API 查找数字平均值的示例。但我觉得,同样可以使用 reduce() 来完成。
public class Test {
public static void main(String[] args) {
// Using collect
System.out.println(Stream.of(1, 2, 3, 4, 5, 6, 7, 8, 9, 10)
.collect(Averager::new, Averager::accept, Averager::combine)
.average());
// Using reduce
System.out.println(Stream.of(1, 2, 3, 4, 5, 6, 7, 8, 9, 10)
.reduce(new Averager(), (t, u) -> {
t.accept(u);
return t;
}, (t, u) -> {
t.combine(u);
return t;
}).average());
}
private static class Averager {
private int total = 0;
private int count = 0;
public Averager() {
// System.out.println("Creating averager");
}
public double average() {
// System.out.println("Finding average");
return count > 0 ? ((double) total) / count : 0;
}
public void accept(int i) {
// System.out.println("Accepting " + i);
total += i;
count++;
}
public void combine(Averager other) {
// System.out.println("Combining the averager : " + other);
total += other.total;
count += other.count;
}
@Override
public String toString() {
return "[total : " + total + ", count: " + count + "]";
}
}
}
1) 有什么理由我应该在这里使用 collect 而不是 reduce 吗?
2)如果我启用所有调试系统输出,我可以看到在收集和减少之间执行的操作完全相同。在这两种情况下,组合器都没有被使用。
3)如果我让流并行,收集总是返回正确的结果。 reduce() 每次都给我不同的结果。
4) 我不应该在并行流中使用reduce吗?
谢谢,
保罗
【问题讨论】:
标签: java lambda functional-programming java-8 java-stream