jdk8 lambda表达式list操作分组、过滤、求和、最值、排序、去重(1)

//过滤指定查询条件(查询age>15并且age<18的数据) public static void Test1(List<TestVO> list) { List<TestVO> collect = list.stream().filter((e) -> e.getAge() > 15 && e.getAge() < 18 ).collect(Collectors.toList()); System.out.println("过滤后的数据为"); TestVO.printStudents(collect); }

根据指定列分组

public static void Test2(List<TestVO> list) { Map<Integer, List<TestVO>> map = list.stream().collect(Collectors.groupingBy(TestVO::getAge)); System.out.println("根据指定列分组" + map); }

通过map获取指定列集合

public static void Test3(List<TestVO> list) { List<Integer> ageList = list.stream() .map(TestVO::getAge) .collect(Collectors.toList()); System.out.println("通过map获取指定年龄列集合" + ageList); }

根据 List 中 Object 某个属性去重

public static void Test4() { //测试数据,请不要纠结数据的严谨性 List<TestVO> list = new ArrayList<>(); list.add(new TestVO(1, "李小明", 18)); list.add(new TestVO(2, "李小明", 19)); list.add(new TestVO(3, "王大朋", 16)); list.add(new TestVO(4, "陈小跑", 10)); // 这里我们引入了两个静态方法,以及通过 TreeSet<> 来达到获取不同元素的效果 // 1. import static java.util.stream.Collectors.collectingAndThen; // 2. import static java.util.stream.Collectors.toCollection; ArrayList<TestVO> collect = list.stream().collect(collectingAndThen(toCollection(() -> new TreeSet<>(Comparator.comparing(TestVO::getName))), ArrayList::new)); TestVO.printStudents(collect); /* ---------------------------------------------------------- TestVO(id=1, name=李小明, age=18) TestVO(id=3, name=王大朋, age=16) TestVO(id=4, name=陈小跑, age=10)*/ }

//list统计(求和、最大、最小、平均)

public static void Test5() { //测试数据,请不要纠结数据的严谨性 List<TestVO> list = new ArrayList<>(); list.add(new TestVO(1, "李小明", 18)); list.add(new TestVO(2, "李小明", 19)); list.add(new TestVO(3, "王大朋", 16)); list.add(new TestVO(4, "陈小跑", 10)); double sum = list.stream().mapToDouble(TestVO::getAge).sum();//和 OptionalDouble max = list.stream().mapToDouble(TestVO::getAge).max();//最大 OptionalDouble min = list.stream().mapToDouble(TestVO::getAge).min();//最小 OptionalDouble average = list.stream().mapToDouble(TestVO::getAge).average();//平均值 System.out.println("和" + sum); System.out.println("最大" + max.getAsDouble()); System.out.println("最小" + min.getAsDouble()); System.out.println("平均值" + average.getAsDouble()); /* 和63.0 最大19.0 最小10.0 平均值15.75*/ }

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
bbs.csdn.net/topics/618164986)

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值