据我所知,List<Double>
使用Java 8流求和的方法是:
List<Double> vals = . . . ;
double sum = vals.stream().mapToDouble(Double::doubleValue).sum();
在我mapToDouble(Double::doubleValue)
看来,这似乎很不礼貌-只是应该放弃lambda和数据流的样板“仪式”。
最佳实践告诉我们,List
实例比数组更可取,但是对于这种求和,数组看起来更干净:
double[] vals = . . . ;
double sum = Arrays.stream(vals).sum();
当然,可以做到这一点:
List<Double> vals = . . . ;
double sum = vals.stream().reduce(0.0, (i,j) -> i+j);
但这reduce(....)
比更长sum()
。
我知道这与需要围绕Java的非对象原语对流进行改造的方式有关,但是,我在这里还缺少什么吗?有什么方法可以压缩自动装箱以使其更短吗?还是这只是当前的最新状态?
更新-答案摘要
以下是答案的摘要。我在这里进行总结时,我敦促读者自己仔细阅读答案。
@dasblinkenlight解释说,由于Java历史中更进一步的决策,特别是在实现泛型的方式及其与非对象原语的关系方面,总是需要某种类型的拆箱。他指出,从理论上讲,编译器可以进行拆箱操作并允许使用更简短的代码,但这尚未实现。
@Holger显示了一个非常接近我所要表达的解决方案:
double sum = vals.stream().reduce(0.0, Double::sum);
我没有意识到新的静态Double.sum()
方法。加上1.8,似乎是出于我所描述的目的。我还发现了Double.min()
和Double.max()
。展望未来,我一定会将此习语用于类似的操作List<Double>
。