java1.8中Lambda表达式reduce聚合测试例子

时间:2016-05-10 18:33:02   收藏:0   阅读:509
public class LambdaTest {

    public static void main(String[] args) {
        // 相当于foreach遍历操作结果值
        Integer out = Stream.of(10, 5, 3, 2, 1, 0).reduce((result, item) -> {
            if (item >= 3) {
                result = result + item;
            }
            return result;
        }).get();
        System.out.println(out);

        // 相当于给定初始结果值,foreach遍历操作结果值
        Integer sum = Stream.of(10, 5, 3, 2, 1, 0).reduce(9, LambdaTest::sumTest);
        System.out.println(sum);

        //相当于给定初始结果值,两个foreach遍历操作结果值
        int str = Stream.of(1,2,3).parallel().reduce(1, (result, item) -> {
            return result + item;
        } , (result, item) -> {
            //注:只有并行parallel下才会进入此方法
            return result + item ;
        });
        System.out.println(str);
    }

    //替换Integer::sum测试
    public static Integer sumTest(int a1, int a2) {
        return a1 + a2;
    }

}

 

原文:http://www.cnblogs.com/rgky/p/5478561.html

评论(0
© 2014 bubuko.com 版权所有 - 联系我们:wmxa8@hotmail.com
打开技术之扣,分享程序人生!