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)
相关推荐
编程充电站pro11 分钟前
SQL 面试高频:INNER JOIN vs LEFT JOIN 怎么考?
数据库·sql
这周也會开心13 分钟前
SQL-窗口函数做题总结
数据库·sql
间彧29 分钟前
TiDB详解与Spring Boot实战指南
数据库
极限实验室30 分钟前
Easysearch 字段'隐身'之谜:source_reuse 与 ignore_above 的陷阱解析
数据库·redis
2301_7720935637 分钟前
tuchuang_后端_前端_注册登录
数据库·后端·网络协议·mysql·wireshark
武子康1 小时前
Java-141 深入浅出 MySQL Spring事务失效的常见场景与解决方案详解(3)
java·数据库·mysql·spring·性能优化·系统架构·事务
间彧1 小时前
脏读、不可重复读、幻读详解与对比
数据库
间彧1 小时前
数据库事务隔离级别详解
数据库
朝九晚五ฺ1 小时前
【Redis学习】Redis常用数据类型的万字详解
redis·学习·哈希算法
fwerfv3453452 小时前
使用PyTorch构建你的第一个神经网络
jvm·数据库·python