Java,SpringBoot中对Stream流的运用

详细参考:java 1.8 stream 应用-22种案例_java1.8 流案例-CSDN博客

准备条件

java 复制代码
public class Books implements Serializable {

    private static final long serialVersionUID = 1L;

    /**
     * 图书记录ID,自增
     */

    private Integer bookId;

    /**
     * 图书号
     */
    private String bookCode;

    /**
     * 图书类型
     */
    private String bookType;

    /**
     * 图书名称
     */
    private String bookName;

    /**
     * 作者名称
     */
    private String authorName;

    /**
     * 出版社
     */
    private String publisher;

    /**
     * 总数量
     */
    private Integer totalQuantity;
}
java 复制代码
        List<Books> list = booksMapper.findBooksName(null); // 查询全部

Stream流对集合的应用

  1. 遍历
java 复制代码
List<Books> bookList = // 获取你的书籍列表

// 使用 Stream API 遍历列表
bookList.forEach(book -> {
    // 在这里不执行其他操作,只是遍历
    System.out.println(book); // 或者其他你想要的操作
});
  1. 汇总
java 复制代码
List<Books> bookList = // 获取你的书籍列表

// 1. 过滤(Filtering):保留总数量大于0的图书
List<Books> filteredBooks = bookList.stream()
                                   .filter(book -> book.getTotalQuantity() > 0)
                                   .collect(Collectors.toList());

// 2. 映射(Mapping):提取图书名称形成新的列表
List<String> bookNames = bookList.stream()
                                .map(Books::getBookName)
                                .collect(Collectors.toList());

// 3. 计数(Counting):计算图书总数
long bookCount = bookList.stream().count();

// 4. 查找(Finding):找到集合中的任意一本图书
Optional<Books> anyBook = bookList.stream().findAny();
Optional<Books> firstBook = bookList.stream().findFirst();

// 5. 排序(Sorting):按照图书名称排序
List<Books> sortedBooks = bookList.stream()
                                 .sorted(Comparator.comparing(Books::getBookName))
                                 .collect(Collectors.toList());

// 6. 分组(Grouping):按照图书类型分组
Map<String, List<Books>> booksByType = bookList.stream()
                                               .collect(Collectors.groupingBy(Books::getBookType));

// 7. 分区(Partitioning):将图书分为数量大于0和数量为0的两部分
Map<Boolean, List<Books>> partitionedBooks = bookList.stream()
                                                    .collect(Collectors.partitioningBy(book -> book.getTotalQuantity() > 8));

Map集合运用Stream流

java 复制代码
import java.util.HashMap;
import java.util.Map;

public class StreamExample {

    public static void main(String[] args) {
        // 创建一个包含学生姓名和对应成绩的Map集合
        Map<String, Integer> studentScores = new HashMap<>();
        studentScores.put("Alice", 85);
        studentScores.put("Bob", 92);
        studentScores.put("Charlie", 78);
        studentScores.put("David", 95);
        studentScores.put("Eva", 88);

        // 使用Stream流处理Map集合
        studentScores.entrySet().stream()
                // 过滤出成绩大于等于90的学生
                .filter(entry -> entry.getValue() >= 90)
                // 获取学生姓名并打印
                .map(Map.Entry::getKey)
                .forEach(System.out::println);
    }
}
相关推荐
荔枝hu13 分钟前
springboot生成pdf方案之dot/html/图片转pdf三种方式
spring boot·pdf·html
Otaku love travel36 分钟前
老系统改造增加初始化,自动化数据源配置(tomcat+jsp+springmvc)
java·tomcat·初始化·动态数据源
DKPT1 小时前
Java设计模式之行为型模式(责任链模式)介绍与说明
java·笔记·学习·观察者模式·设计模式
L_autinue_Star1 小时前
手写vector容器:C++模板实战指南(从0到1掌握泛型编程)
java·c语言·开发语言·c++·学习·stl
晨岳1 小时前
CentOS 安装 JDK+ NGINX+ Tomcat + Redis + MySQL搭建项目环境
java·redis·mysql·nginx·centos·tomcat
执笔诉情殇〆1 小时前
前后端分离(java) 和 Nginx在服务器上的完整部署方案(redis、minio)
java·服务器·redis·nginx·minio
元气小嘉1 小时前
前端技术小结
开发语言·前端·javascript·vue.js·人工智能
YuTaoShao1 小时前
【LeetCode 热题 100】24. 两两交换链表中的节点——(解法一)迭代+哨兵
java·算法·leetcode·链表
励志的大鹰哥2 小时前
V少JS基础班之第七弹
开发语言·javascript·ecmascript
程序员的世界你不懂2 小时前
(20)Java+Playwright自动化测试- 操作鼠标拖拽 - 上篇
java·python·计算机外设