Java8 Stream 强大功能之统计、汇总、多字段分组和多个列汇总统计【含面试题】

面试题分享点我直达

2023最新面试合集链接

2023大厂面试题PDF

面试题PDF版本

java、python面试题

项目实战:AI文本 OCR识别最佳实践

AI Gamma一键生成PPT工具直达链接

玩转cloud Studio 在线编码神器

玩转 GPU AI绘画、AI讲话、翻译,GPU点亮AI想象空间

史上最全文档AI绘画stablediffusion资料分享

AI绘画关于SD,MJ,GPT,SDXL百科全书

AI绘画 stable diffusion Midjourney 官方GPT文档 AIGC百科全书资料收集

AIGC资料包

在现代Java开发中,Stream API 已经

成为一个强大的工具,它提供了一种简洁而灵活的方式来处理集合数据。其中,Stream API 统计、汇总、多字段分组和多个列汇总统计是使用频率较高的功能。本文将深入介绍这些功能,并提供一些代码示例。

一、统计功能:

  1. count():返回流中元素的总数。
  2. min() 和 max():返回流中的最小值和最大值。
  3. average():返回流中元素的平均值。
  4. sum():对流中的元素求和。

示例代码:

java 复制代码
List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5);

long count = numbers.stream().count();
Optional<Integer> max = numbers.stream().max(Integer::compareTo);
Optional<Integer> min = numbers.stream().min(Integer::compareTo);
double average = numbers.stream().mapToInt(Integer::intValue).average().orElse(0);
int sum = numbers.stream().mapToInt(Integer::intValue).sum();

二、汇总功能:

  1. reduce():将流中的元素进行累积计算,返回一个 Optional 对象。
  2. collect():将流中的元素收集到一个容器对象中,如 List、Set 或 Map。

示例代码:

java 复制代码
List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5);

Optional<Integer> sum = numbers.stream().reduce(Integer::sum);
List<Integer> squaredNumbers = numbers.stream().map(n -> n * n).collect(Collectors.toList());
Set<Integer> evenNumbers = numbers.stream().filter(n -> n % 2 == 0).collect(Collectors.toSet());
Map<String, List<Integer>> groupByOddEven = numbers.stream().collect(Collectors.groupingBy(n -> n % 2 == 0 ? "Even" : "Odd"));

三、多字段分组:

使用 Collectors.groupingBy 方法可以实现对流中元素的多字段分组。

示例代码:

java 复制代码
class Person {
    private String name;
    private int age;
    private String gender;

    // 省略构造函数和 Getter/Setter 方法

    @Override
    public String toString() {
        return "Person{" +
                "name='" + name + '\'' +
                ", age=" + age +
                ", gender='" + gender + '\'' +
                '}';
    }
}

List<Person> people = Arrays.asList(
        new Person("Alice", 20, "Female"),
        new Person("Bob", 30, "Male"),
        new Person("Charlie", 25, "Male"),
        new Person("David", 22, "Male"),
        new Person("Eva", 28, "Female"),
        new Person("Frank", 35, "Male")
);

Map<String, List<Person>> byGender = people.stream().collect(Collectors.groupingBy(Person::getGender));
Map<Integer, List<Person>> byAge = people.stream().collect(Collectors.groupingBy(Person::getAge));

四、多个列汇总统计:

使用 Collectors.groupingBy 方法结合 Collectors.summarizingInt 方法可以实现对流中元素的多个列进行汇总统计。

示例代码:

java 复制代码
class Product {
    private String category;
    private String name;
    private int price;
    private int quantity;

    // 省略构造函数和 Getter/Setter 方法

    @Override
    public String toString() {
        return "Product{" +
                "category='" + category + '\'' +
                ", name='" + name + '\'' +
                ", price=" + price +
                ", quantity=" + quantity +
                '}';
    }
}

List<Product> products = Arrays.asList(
        new Product("Electronics", "Laptop", 2500, 5),
        new Product("Electronics", "Phone", 800, 3),
        new Product("Clothing", "Shirt", 40, 10),
        new Product("Clothing", "Pants", 60, 8),
        new Product("Books", "Java in Action", 50, 15),
        new Product("Books", "Clean Code", 80, 12)
);

Map<String, IntSummaryStatistics> statsByCategory = products.stream().collect(Collectors.groupingBy(Product::getCategory, Collectors.summarizingInt(Product::getQuantity)
相关推荐
Raymond运维4 小时前
MariaDB源码编译安装(二)
运维·数据库·mariadb
沢田纲吉4 小时前
🗄️ MySQL 表操作全面指南
数据库·后端·mysql
Seven975 小时前
剑指offer-31、整数中1出现的次数
redis
RestCloud19 小时前
SQL Server到Hive:批处理ETL性能提升30%的实战经验
数据库·api
RestCloud19 小时前
为什么说零代码 ETL 是未来趋势?
数据库·api
ClouGence1 天前
CloudCanal + Paimon + SelectDB 从 0 到 1 构建实时湖仓
数据库
DemonAvenger1 天前
NoSQL与MySQL混合架构设计:从入门到实战的最佳实践
数据库·mysql·性能优化
AAA修煤气灶刘哥2 天前
别让Redis「歪脖子」!一次搞定数据倾斜与请求倾斜的捉妖记
redis·分布式·后端
AAA修煤气灶刘哥2 天前
后端人速藏!数据库PD建模避坑指南
数据库·后端·mysql
RestCloud2 天前
揭秘 CDC 技术:让数据库同步快人一步
数据库·api