基于Java8的Lambda表达式(2)

上一篇文章:基于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.说明
  • filter
    filter函数需要传入一个实现Predicate函数式接口的对象,该接口的抽象方法test接收一个参数并返回一个boolean值,留下返回true的数据。

  • flatMap
    flatMap函数(注意flat这个单词,很形象),类似把一个二组数组的元素,扁平化到一维数组里。对多个流的整合处理有较大作用。

  • parallel
    书上说是针对多核处理器的一种并行操作,暂时还没体会到效果。

  • reduce
    reduce函数也很形象(类似sql语句里的sum函数),把stream里的一串数据经过处理缩减为一个数据。

  • distinct、limit、skip、findFirst、max、min
    以上函数看名称就大概知道什么意思,大家可以都去试一下。

由于作者水平有限,难免出现纰漏,如有问题请帮忙指正,谢谢!
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容