常用Lamda表达式

常用Lamda表达式1、在工作中我们有部分lamda表达式经常会用到,在此做个小总结这里新建个实体类,来做测试publicclassLamdaVO{privateIntegerid;privateStringname;privateStringeamil;publicLamdaVO(){}publicLamdaVO(Integ…

大家好,又见面了,我是你们的朋友全栈君。

1、在工作中我们有部分lamda表达式经常会用到,在此做个小总结

这里新建个实体类,来做测试

public class LamdaVO {
    private Integer id;
    private String name;
    private String eamil;

    public LamdaVO() {
    }

    public LamdaVO(Integer id, String name, String eamil) {
        this.id = id;
        this.name = name;
        this.eamil = eamil;
    }

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getEamil() {
        return eamil;
    }

    public void setEamil(String eamil) {
        this.eamil = eamil;
    }

    @Override
    public String toString() {
        return "LamdaVO{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", eamil='" + eamil + '\'' +
                '}';
    }
}

对lamda用的比较多的几种,做一下展示

public class FreemakeraddApplicationTests {

    @Test
    public void lamdaTest() {
        List<LamdaVO> lamdaVOList = new ArrayList<>();
        LamdaVO user1 = new LamdaVO(1, "小明", "12324qq.com");
        LamdaVO user2 = new LamdaVO(2, "小芳", "12324qq.com");
        LamdaVO user3 = new LamdaVO(3, "小华", "12324qq.com1");
        LamdaVO user4 = new LamdaVO(4, "小华", "12324qq.com2");

        lamdaVOList.add(user1);
        lamdaVOList.add(user2);
        lamdaVOList.add(user3);
        lamdaVOList.add(user4);

        //lamda表达式 过滤加遍历
        System.out.println("lamda表达式 过滤加遍历");
        lamdaVOList.stream().filter(u -> u.getId() > 1).
                forEach(u -> System.out.println(u.getId() + ":::" + u.getName()));

        //lamda表达式对提取为map对象
        
        
        // Map<String, String> map = lamdaVOList.stream().
         //       collect(Collectors.toMap(LamdaVO::getName, LamdaVO::getEamil));
        //如果采用上面方式需要特别注意,使用Collectors.toMap时,需要保证生成map的唯一性,否则会报
       // java.lang.IllegalStateException: Duplicate key 错误。可以采用下面的方式规避,
       //下面  (o, n) -> o表示的 如果出现重复key,则用 原来代替新的key,所以打印的小华的邮箱 为
     //   小华::12324qq.com1.同样可以使用  (o, n) -> n 这样当出现重复key时候,则会用新的key代替老的key了,
     // 此时 打印的小华的邮箱  则为   小华::12324qq.com2


        System.out.println("lamda表达式对提取为map对象");
        Map<String, String> map = lamdaVOList.stream().
                collect(Collectors.toMap(LamdaVO::getName, LamdaVO::getEamil, (o, n) -> o));
        for (Map.Entry<String, String> entry : map.entrySet()) {
            System.out.println(entry.getKey()+"---"+entry.getValue());
        }

        //lamda 表达式对对象里面某个属性提取List对象
        System.out.println("lamda 表达式对对象里面某个属性提取List对象");
        List<String> list = lamdaVOList.stream().map(LamdaVO::getName).collect(Collectors.toList());
        list.stream().forEach(s-> System.out.println(s));

        //lamda表达式变为map<String,List<String>>
        System.out.println("lamda表达式变为map<String,List<String>>");
        Map<String, List<LamdaVO>> map2 = lamdaVOList.stream().collect(Collectors.groupingBy(LamdaVO::getName));
        for (Map.Entry<String, List<LamdaVO>> entry : map2.entrySet()) {
            System.out.println(entry.getKey()+"::"+entry.getValue());
        }

   }

}

查看lamda表达式的输出结果:
常用Lamda表达式

我们在使用lamda表达式排序的时候,很多时候考虑到空指针可能会选择传统的方式,lamda实际上也有防止空指针的排序。

 @Test
    public void lamdaCompareTest(){
        LamdaVO lamdaVO1 = new LamdaVO(null, "name1", "eamil1");
        LamdaVO lamdaVO2 = new LamdaVO(2, "name2", "eamil2");
        LamdaVO lamdaVO3 = new LamdaVO(3, "name3", "eamil3");
        LamdaVO lamdaVO4 = new LamdaVO(null, "name4", "eamil4");
        LamdaVO lamdaVO5 = new LamdaVO(5, "name5", "eamil6");

        List<LamdaVO> lamdaLst = new ArrayList<>();
        lamdaLst.add(lamdaVO1);
        lamdaLst.add(lamdaVO2);
        lamdaLst.add(lamdaVO3);
        lamdaLst.add(lamdaVO4);
        lamdaLst.add(lamdaVO5);

        List<LamdaVO> nullLastPositive = lamdaLst.stream().sorted(Comparator.comparing(LamdaVO::getId, Comparator.nullsLast(Integer::compareTo))).collect(Collectors.toList());
        System.out.println("null在最后正序:"+nullLastPositive);

        List<LamdaVO> nullLastReverse = lamdaLst.stream().sorted(Comparator.comparing(LamdaVO::getId, Comparator.nullsLast(Integer::compareTo)).reversed()).collect(Collectors.toList());
        System.out.println("null在最后正序:"+nullLastReverse);

        List<LamdaVO> nullFirst = lamdaLst.stream().sorted(Comparator.comparing(LamdaVO::getId, Comparator.nullsFirst(Integer::compareTo))).collect(Collectors.toList());
        System.out.println("null在最前:"+nullFirst);
        List<LamdaVO> list = lamdaLst.stream().sorted(Comparator.comparing(LamdaVO::getId)).collect(Collectors.toList());
        System.out.println(list);

    }

结果:

在这里插入图片描述
在排序中添加类似这种Comparator.nullsLast(Integer::compareTo)) ,是可以防止lamda报空指针异常的

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/132241.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • pycharm全局搜索(mac)

    pycharm全局搜索(mac)command+shift+f

    2022年5月31日
    73
  • i am running什么意思_hirunning

    i am running什么意思_hirunningnmtui提示:NetworkManagerisnotrunning.启动:sudoservicenetwork-managerstart提示:Redirectingto/bin/systemctlstartnetwork-manager.serviceFailedtostartnetwork-manager.service:Unitnotfound.安装:yuminstallNetworkManager-tui…

    2022年9月28日
    0
  • debug灯在哪_shutterbug

    debug灯在哪_shutterbug

    2022年8月20日
    4
  • 起步上路「建议收藏」

    起步上路「建议收藏」始于2016-09-11开篇,中间基于工作的内容,记录了几篇相关内容的博客,离上一次发博客(2017-07-24),也过了1年多的时间。这个期间,开始转战人工智能方向,深度学习算法的内容。几经磨难,算是踏入门槛,期间也记录了些许内容。期间也看了各路朋友相关的博客内容,其中不乏精彩之作,为初学者提供了很好的帮助。目前接触和比较熟悉的是目标检测相关的内容,大多基于caffe深度学习框架,博客内容不…

    2022年6月9日
    48
  • Rewritecond介绍

    Rewritecond介绍RewriteCondSyntax:RewriteCondTestStringCondPattern[flags]  RewriteCond指令定义一条规则条件。在一条RewriteRule指令前面可能会有一条或多条RewriteCond指令,只有当自身的模板(pattern)匹配成功且这些条件也满足时规则才被应用于当前URL处理。  TestString是一个字符串,除了包含普通的

    2022年6月13日
    20
  • 使用sp_executesql存储过程执行动态SQL查询

    使用sp_executesql存储过程执行动态SQL查询Thesp_executesqlstoredprocedureisusedtoexecutedynamicSQLqueriesinSQLServer.AdynamicSQLqueryisaqueryinstringformat.ThereareseveralscenarioswhereyouhaveanSQLq…

    2022年5月21日
    29

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号