reduce归约:深入理解java8中的归约reduce

🍰 个人主页:_小白不加班__
🍞文章有不合理的地方请各位大佬指正。
🍉文章不定期持续更新,如果我的文章对你有帮助➡️ 关注🙏🏻 点赞👍 收藏⭐️

常见场景图示

我们常见使用场景:累加、求最大值 如图示
累加:在这里插入图片描述

求最大值:在这里插入图片描述

reduce中的BiFunctionBinaryOperator是什么

reduce定义如下:
T reduce(T identity, BinaryOperator<T> accumulator);

首先了解一下BiFunctionBinaryOperator
带有BinaryBi关键字都是二元运算(就是谓词带有 有两个形参)
在这里插入图片描述
BiFunction函数式接口如下:
传入 T类型变量t U类型变量u 返回R类型变量

@FunctionalInterface
// (T t,U u)->R
public interface BiFunction<T, U, R> {
    R apply(T t, U u);
}

BinaryOperator函数式接口如下:
继承BiFunction 形参类型和返回类型相同

@FunctionalInterface
public interface BinaryOperator<T> extends BiFunction<T,T,T> {
    
}

理解reduce

reduce常见的定义方式:
T reduce(T identity, BinaryOperator accumulator);
Optional<T> reduce(BinaryOperator<T> accumulator);

下面详细解释

T reduce(T identity, BinaryOperator accumulator);

第一个参数传入T类型值,第二分谓词 (T t,T t)->T 返回值类型为T

通俗点总结:
一个初始值
一个Lambda来把两个流元素结合起来并产生一个新值
常用:累加、累积

Optional reduce(BinaryOperator accumulator);

谓词 (T t,T t)->T 返回值类型为T

Optional容器类表示一个值存在或者不存在,避免和null检查

reduce要考虑新的值和下一个元素,将流中的第一个元素作为初始值,比较产生最大值,然后继续和下一个元素比较。
常用:最大值,最小值

代码举例

最开始的图示的代码如下:
累加:

List<Integer> integers = Arrays.asList(4, 5, 3, 9);
Integer reduce = integers.stream().reduce(0, (a, b) -> a + b);
System.out.println("求和:"+reduce);
//求和:21

在这里插入图片描述
求最大值

List<Integer> integers = Arrays.asList(4, 5, 3, 9);
Optional<Integer> reduce = integers.stream().reduce(Integer::max);
System.out.println("最大值:" + reduce.get());
//最大值:9

在这里插入图片描述
Optional的详细使用改天再更,关注不错过~~~~

🍉文章不定期持续更新,如果我的文章对你有帮助 ➡️ 关注 👍点赞 ⭐️收藏
🙏🏻 你们的支持是我 更新的动力

  • 73
    点赞
  • 43
    收藏
    觉得还不错? 一键收藏
  • 27
    评论
评论 27
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值