java的lambda骚操作,会几个常用写法感觉档次都不一样了

介绍语

本号主要是Java常用关键技术点,通用工具类的分享;以及springboot+springcloud+Mybatisplus+druid+mysql+redis+swagger+maven+docker等集成框架的技术分享;datax、kafka、flink等大数据处理框架的技术分享。文章会不断更新,欢迎码友关注点赞收藏转发!

望各位码友点击关注,冲1000粉。后面会录制一些视频教程,图文和视频结合,比如:图书介绍网站系统、抢购系统、大数据中台系统等。技术才是程序猿的最爱,码友们冲啊

如果码友觉得代码太长,可以从头到尾快速扫射一遍,了解大概即可。觉得有用后再转发收藏,以备不时之需。

正文:

java的stream用的概率越来越大了,lambda链式写法也越来越让人爱不释手。java的stream api还有很多,是值得好好探索一番的。直接上几个例子,没啥技术含量,只是总结了使用频率较高的几种类型。

  1. 过滤年龄小于10的人;
  2. 按地址分组;
  3. 按地址分组,然后统计薪水情况;
  4. 求最大薪水;
  5. 按年龄从小到大排序;
  6. 按年龄从大到小排序,年龄相同在按名字排序;
 import com.alibaba.fastjson.JSON;
 
 import java.util.ArrayList;
 import java.util.Arrays;
 import java.util.Comparator;
 import java.util.IntSummaryStatistics;
 import java.util.List;
 import java.util.Map;
 import java.util.Objects;
 import java.util.stream.Collectors;
 
 /**
  * @author java老牛
  */
 public class LambdaExample {
 
     public static void main(String[] args) {
         String[] str = {"java", "lao", "niu", "爱", "分", "享"};
         List list = Arrays.asList(str);
 
         System.out.println("// 最简单的Lambda");
         list.forEach(s -> System.out.print(s + "-"));
         System.out.println("");
 
         List poList = new ArrayList<>();
         poList.add(new UserPO("zhang三", 12, "01", 100.2, "北京"));
         poList.add(new UserPO("李四", 18, "01", 990.2, "北京"));
         poList.add(new UserPO("王五", 15, "02", 45.8, "深圳"));
         poList.add(new UserPO("八戒", 8, "02", 1000.8, "上海"));
         poList.add(new UserPO("悟空", 9, "02", 100.2, "上海"));
         poList.add(new UserPO("小红", 12, "01", 50.2, "上海"));
 
         System.out.println("// 过滤年龄小于10的人");
         List collect1 = poList.stream().filter(u -> u.getAge() > 10).collect(Collectors.toList());
         collect1.forEach(s -> System.out.println(JSON.toJSON(s)));
 
         System.out.println("// 按地址分组");
         Map> collect2 = poList.stream().collect(Collectors.groupingBy(UserPO::getAddress));
         collect2.forEach((k, v) -> {
             System.out.println(k);
             System.out.println(JSON.toJSON(v));
         });
 
         System.out.println("// 按地址分组,然后统计薪水情况");
         Map collect3 = poList.stream().collect(
             Collectors.groupingBy(UserPO::getAddress, Collectors.summarizingInt(UserPO::getAge)));
         collect3.forEach((k, s) -> {
             System.out.println("===============" + k + "==========");
             System.out.println("求和:" + s.getSum());
             System.out.println("求平均" + s.getAverage());
             System.out.println("求最大:" + s.getMax());
             System.out.println("求最小:" + s.getMin());
             System.out.println("求总数:" + s.getCount());
         });
 
         System.out.println("// 求最大薪水");
         Double max = poList.stream().map(UserPO::getSalary).filter(Objects::nonNull).reduce((double) 0, Double::max);
         System.out.println("max salary: " + max);
 
 
         System.out.println("// 按年龄从小到大排序");
         List collect4 =
             poList.stream().sorted(Comparator.comparing(UserPO::getAge)).collect(Collectors.toList());
         collect4.forEach(s -> System.out.println(JSON.toJSON(s)));
 
         System.out.println("// 按年龄从大到小排序,年龄相同在按名字排序");
         List collect5 =
             poList.stream().sorted(Comparator.comparing(UserPO::getAge).thenComparing(UserPO::getUsername).reversed())
                 .collect(Collectors.toList());
         collect5.forEach(s -> System.out.println(JSON.toJSON(s)));
     }
 
 
 }
 
 import lombok.AllArgsConstructor;
 import lombok.Data;
 
 /**
  * @author java老牛
  */
 @Data
 @AllArgsConstructor
 public class UserPO {
 
     private String username;
 
     private Integer age;
 
     private String sex;
 
     private Double salary;
 
     private String address;
 }

打印结果:

java的lambda骚操作,会几个常用写法感觉档次都不一样了


maven依赖

 
   org.projectlombok
   lombok
   1.18.24
 


鄙人编码十年多,在项目中也积累了一些工具类,很多工具类在每个项目都有在用,很实用。大部分是鄙人封装的,有些工具类是同事封装的,有些工具类已经不记得是ctrl+c的还是自己封装的了,现在有空就会总结项目中大部分的工具类,分享给各位码友。如果文章中涉及的代码有侵权行为请通知鄙人处理。

计划是先把工具类整理出来,正所谓工欲善其事,必先利其器。项目中不管是普通单体项目还是多模块maven项目或是分布式微服务,一部分功能模块都是可以重用的,工具类模块就是其中之一。

发表评论
留言与评论(共有 0 条评论) “”
   
验证码:

相关文章

推荐文章