专栏名称: Java基基
一个苦练基本功的 Java 公众号,所以取名 Java 基基
目录
相关文章推荐
青塔  ·  985,迎来新副校长! ·  2 天前  
生态梦网  ·  速投简历!一大波好工作来了 ·  昨天  
生态梦网  ·  集市!夜市!生态城这里太热闹了 ·  2 天前  
青塔  ·  医启未来!浙江大学医学院全球聚才 ·  6 天前  
51好读  ›  专栏  ›  Java基基

Java 8 Stream 之 collect() 的奇技淫巧

Java基基  · 公众号  ·  · 2024-04-14 19:57

正文

👉 这是一个或许对你有用 的社群

🐱 一对一交流/面试小册/简历优化/求职解惑,欢迎加入 芋道快速开发平台 知识星球。 下面是星球提供的部分资料:

👉 这是一个或许对你有用的开源项目

国产 Star 破 10w+ 的开源项目,前端包括管理后台 + 微信小程序,后端支持单体和微服务架构。

功能涵盖 RBAC 权限、SaaS 多租户、数据权限、商城、支付、工作流、大屏报表、微信公众号等等功能:

  • Boot 仓库:https://gitee.com/zhijiantianya/ruoyi-vue-pro
  • Cloud 仓库:https://gitee.com/zhijiantianya/yudao-cloud
  • 视频教程:https://doc.iocoder.cn
【国内首批】支持 JDK 21 + SpringBoot 3.2.2、JDK 8 + Spring Boot 2.7.18 双版本

源:blog.csdn.net/qq_35387940/

article/details/127008965


前言

本身我是一个比较偏向少使用Stream的人,因为调试比较不方便。

但是, 不得不说,stream确实会给我们编码带来便捷。

所以还是忍不住想分享一些奇技淫巧。

基于 Spring Boot + MyBatis Plus + Vue & Element 实现的后台管理系统 + 用户小程序,支持 RBAC 动态权限、多租户、数据权限、工作流、三方登录、支付、短信、商城等功能

  • 项目地址:https://github.com/YunaiV/ruoyi-vue-pro
  • 视频教程:https://doc.iocoder.cn/video/

正文

Stream流 其实操作分三大块 :

  • 创建
  • 处理
  • 收集

我今天想分享的是 收集 这part的玩法。

OK,开始结合代码示例一起玩下:

lombok依赖引入,代码简洁一点:

<dependency>
    <groupId>org.projectlombokgroupId>
    <artifactId>lombokartifactId>
    <version>1.18.20version>
    <scope>compilescope>
dependency>

准备一个UserDTO.java

/**
 * @Author: JCccc
 * @Description:
 */

@Data
public class UserDTO {
 
    /**
     * 姓名
     */

    private  String name;
    /**
     * 年龄
     */

    private  Integer age;
    /**
     * 性别
     */

    private  String sex;
    /**
     * 是否有方向
     */

    private  Boolean hasOrientation;
 
}

准备一个模拟获取List的函数:

private static List getUserList() {
    UserDTO userDTO = new UserDTO();
    userDTO.setName("小冬");
    userDTO.setAge(18);
    userDTO.setSex("男");
    userDTO.setHasOrientation(false);
    UserDTO userDTO2 = new UserDTO();
    userDTO2.setName("小秋");
    userDTO2.setAge(30);
    userDTO2.setSex("男");
    userDTO2.setHasOrientation(true);
    UserDTO userDTO3 = new UserDTO();
    userDTO3.setName("春");
    userDTO3.setAge(18);
    userDTO3.setSex("女");
    userDTO3.setHasOrientation(true);
    List userList = new ArrayList<>();
    userList.add(userDTO);
    userList.add(userDTO2);
    userList.add(userDTO3);
    return userList;
}

第一个小玩法

将集合通过 Stream.collect() 转换成其他集合/数组:

现在拿 List 做例子

转成 HashSet

List userList = getUserList();

Stream usersStream = userList.stream();

HashSet usersHashSet = usersStream.collect(Collectors.toCollection(HashSet::new));

转成 Set usersSet

List userList = getUserList();

Stream usersStream = userList.stream();

Set usersSet = usersStream.collect(Collectors.toSet());

转成 ArrayList

List userList = getUserList();

Stream usersStream = userList.stream();

ArrayList usersArrayList = usersStream.collect(Collectors.toCollection(ArrayList::new));

转成 Object[] objects

List userList = getUserList();

Stream usersStream = userList.stream();

Object[] objects = usersStream.toArray();

转成 UserDTO[] users

List userList = getUserList();

Stream usersStream = userList.stream();

UserDTO[] users = usersStream.toArray(UserDTO[]::new);
for (UserDTO user : users) {
    System.out.println(user.toString());
}

第二个小玩法

聚合(求和、最小、最大、平均值、分组)

找出年龄最大:
stream.max()

写法 1:

List userList = getUserList();
Stream usersStream = userList.stream();
Optional maxUserOptional = 
        usersStream.max((s1, s2) -> s1.getAge() - s2.getAge());
if (maxUserOptional.isPresent()) {
    UserDTO masUser = maxUserOptional.get();
    System.out.println(masUser.toString());
}

写法2:

List userList = getUserList(); Stream usersStream = userList.stream();
Optional maxUserOptionalNew = usersStream.max(Comparator.comparingInt(UserDTO::getAge));
if (maxUserOptionalNew.isPresent()) {
    UserDTO masUser = maxUserOptionalNew.get();
    System.out.println(masUser.toString());
}

效果:

输出:

UserDTO(name=小秋, age=30, sex=男, hasOrientation=true)
找出年龄最小:
stream.min()

写法 1:

Optional minUserOptional = usersStream.min(Comparator.comparingInt(UserDTO::getAge));
if (minUserOptional.isPresent()) {
    UserDTO minUser = minUserOptional.get();
    System.out.println(minUser.toString());
}

写法2:

Optional min = usersStream.collect(Collectors.minBy((s1, s2) -> s1.getAge() - s2.getAge()));
求平均值:
List userList = getUserList();
Stream usersStream = userList.stream();
Double avgScore = usersStream.collect(Collectors.averagingInt(UserDTO::getAge));

效果:

求和:

写法1:

Integer reduceAgeSum = usersStream.map(UserDTO::getAge).reduce(0, Integer::sum);

写法2:

int ageSumNew = usersStream.mapToInt(UserDTO::getAge).sum();
统计数量:






请到「今天看啥」查看全文