JAVA8 Stream接口终端操作reduce操作

对于中间操作和终端操作的定义,请看《JAVA8 stream接口 中间操作和终端操作》,这篇主要讲述的是stream的reduce操作,

reduce 是一种归约操作,将流归约成一个值的操作叫做归约操作,用函数式编程语言的术语来说,这种称为折叠(fold);

我们先看下函数的定义

	T reduce(T identity, BinaryOperator<T> accumulator);
 
	Optional<T> reduce(BinaryOperator<T> accumulator);
 
	<U> U reduce(U identity, BiFunction<U, ? super T, U> accumulator, BinaryOperator<U> combiner);

接口对应的实现如下:

@Override
    public final P_OUT reduce(final P_OUT identity, final BinaryOperator<P_OUT> accumulator) {
        return evaluate(ReduceOps.makeRef(identity, accumulator, accumulator));
    }
 
    @Override
    public final Optional<P_OUT> reduce(BinaryOperator<P_OUT> accumulator) {
        return evaluate(ReduceOps.makeRef(accumulator));
    }
 
    @Override
    public final <R> R reduce(R identity, BiFunction<R, ? super P_OUT, R> accumulator, BinaryOperator<R> combiner) {
        return evaluate(ReduceOps.makeRef(identity, accumulator, combiner));
    }

可以看到,第一个和第三个,是一个重载方法,调用的同一个实现;下面,我们看下具体的小案例

 		List<Integer> numbers = Stream.iterate(1, x -> x + 1).limit(10).collect(Collectors.toList());
        Integer aa = 0;
        for (Integer i : numbers) {
            aa += i;
        }
        Integer dd = numbers.stream().reduce(0, (a, b) -> a + b, (a, b) -> a - b);
        Optional<Integer> dd1 = numbers.stream().reduce((a, b) -> a + b);
        System.out.println(aa);
        System.out.println(dd);
        System.out.println(dd1.get());

我们使用无限流,生成了1-10的数字的list,关于无限流的解释,以及流的创建的方式,可以参看《java8 Stream-创建流的几种方式》

在java8之前,我们对数据求和的,是需要对list进行遍历,然后累加求和的;在案例中,变量aa就是对list遍历累加求和的出处理;从第二段代码中开始,就是java8中的求和方式

T reduce(T identity, BinaryOperator<T> accumulator);

这个函数,接受2个参数,第一个表示初始值,第二个值,传入的是一个函数式接口BinaryOperator,这个接口继承BiFunction;计算的表达式的规则;


Optional<T> reduce(BinaryOperator<T> accumulator);

这个接口。只用传入计算规则,初始值是list的第一个参数,返回的optional对象,预防list里,全部是null;


<U> U reduce(U identity, BiFunction<U, ? super T, U> accumulator, BinaryOperator<U> combiner);

关于这个三个参数的接口,在《java8实战》这本书中,没有做介绍。我也不是特别理解,查阅过一些资料,在多线程中使用的,具体感兴趣的,可以参考《 java8中3个参数的reduce方法怎么理解?》

1.Lambda表达式

JAVA8 Lambda表达式简介
JAVA8 Lambda表达式,方法的引用以及构造器的引用

2.函数式接口

JAVA8 函数式接口简介
JAVA8 Function接口以及同类型的特化的接口
JAVA8 Consumer接口
Supplier接口
JAVA8 Predicate接口
JAVA8 UnaryOperator接口
JAVA8 BiConsumer接口

3.Stream接口操作

JAVA8 Stream接口简介
JAVA8 Stream创建流的几种方式
JAVA8 Stream接口中间操作和终端操作
JAVA8 Stream接口 map操作,filter操作,flatMap操作
JAVA8 Stream接口 distinct,sorted,peek,limit,skip
JAVA8 Stream接口终端操作 forEachOrdered和forEach
JAVA8 Stream接口终端操作 toArray操作
JAVA8 Stream接口终端操作 min,max,findFirst,findAny操作
JAVA8 Stream接口终端操作 count,anyMatch,allMatch,noneMatch
JAVA8 Stream接口终端操作reduce操作
JAVA8 Stream接口终端操作collect操作
JAVA8 Optional静态类简介,以及用法
JAVA8 Stream接口终端操作allMatch 当list为空集合的一些思考
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值