Java8

基于Java8的Lambda表达式(2)

2017-11-23  本文已影响19人  风行者1024

上一篇文章:基于Java8的Lambda表达式(1)
本篇继续讲几个常用的写法:

01.代码
package com.lambda;

import java.util.ArrayList;
import java.util.List;
import java.util.stream.*;

public class TestLambda1 {

    public static void main(String[] args) {
        List<Sales> salesList1 = new ArrayList<>();
        salesList1.add(new Sales("天猫", 1000));
        salesList1.add(new Sales("亚马逊", 200));
        salesList1.add(new Sales("大润发", 600));
        salesList1.add(new Sales("欧尚", 800));
        salesList1.add(new Sales("京东", 8000));

        List<Sales> salesList2 = new ArrayList<>();
        salesList2.add(new Sales("天猫-1", 10));
        salesList2.add(new Sales("亚马逊-1", 20));
        salesList2.add(new Sales("大润发-1", 30));
        salesList2.add(new Sales("欧尚-1", 40));
        salesList2.add(new Sales("京东-1", 50));

        //1. 筛选出销售量大于800的渠道  filter
        List<Sales> list1 = salesList1.stream()
                .filter((sales) -> {
                    //返回true的Sales对象会被留下来
                    return sales.getSaleCount() > 800;
                })
                .collect(Collectors.toList());
        for (Sales s : list1) {
            System.out.println(s.getChannelName() + " " + s.getSaleCount());
        }

        //2. 把两个集合对象里的元素整合到一个集合里  flatMap
        //传统写法
        salesList1.addAll(salesList2);
        for (Sales s : salesList1) {
            System.out.println(s.getChannelName() + " " + s.getSaleCount());
        }
        //lambda写法:体现了对集合类数据的处理特点
        Stream<List<Sales>> inputStream = Stream.of(salesList1,salesList2);
        List<Sales> outputList = inputStream
                .flatMap((childList) -> childList.stream())
                .collect(Collectors.toList());
        for (Sales s : outputList) {
            System.out.println(s.getChannelName() + " " + s.getSaleCount());
        }

        //3, 如果电脑是多核的,可以试试并行计算的效率, parallel
        //可能要针对很耗时的处理问题才有效果吧,我试了常规的测试没啥变化

        //4, 把所有的销售数量累加起来 reduce
        //传统写法
        Integer count1=0;
        for(Sales obj : outputList) {
            count1 += obj.getSaleCount();
        }
        System.out.println(count1);

        //lambda写法
        Integer count2 = outputList.stream()
                //先把Sales对象流转换为销售量Integer的流
                .map(Sales::getSaleCount)
                //叠加Integer
                .reduce(Integer::sum)
                .get();
        System.out.println(count2);
    }
}

02.说明
由于作者水平有限,难免出现纰漏,如有问题请帮忙指正,谢谢!
上一篇 下一篇

猜你喜欢

热点阅读