Java Stream中reduce方法的使用

三种重载的方法
  • 第一种
 Optional<T> reduce(BinaryOperator<T> accumulator);

方法接受一个BinaryOperator类型的lambada表达式, 常规应用方法如下:

 List<Integer> list = Arrays.asList(1,2,3,4);
 int result = list.stream().reduce((a,b) -> a+b).get();
 System.out.println(result);

代码实现了对list 中的元素累加。lambada表达式的a参数是表达式的执行结果的缓存,也就是表达式这一次的执行结果会被作为下一次执行的参数,而第二个参数b则是依次为stream中每个元素。如果表达式是第一次被执行,a则是stream中的第一个元素。

  • 第二种
 T reduce(T identity, BinaryOperator<T> accumulator);

方法接受一个identity和BinaryOperator类型的lambada表达式, 与第一个签名的实现的唯一区别是它首次执行时表达式第一次参数并不是stream的第一个元素,而是通过签名的第一个参数identity来指定。我们来通过这个签名对之前的求和代码进行改进。

List<Integer> list = Arr
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值