如何利用Java Stream进行分组统计

发布时间:2025-02-06 05:43:22 作者:小樊
来源:亿速云 阅读:94

在Java中,你可以使用Stream API和Collectors工具类来进行分组统计

假设我们有一个Person类,其中包含nameage属性:

public class Person {
    private String name;
    private int age;

    public Person(String name, int age) {
        this.name = name;
        this.age = age;
    }

    // getter and setter methods
}

现在,我们有一个List<Person>,我们想要根据年龄对这些人员进行分组统计。我们可以使用以下方法实现:

import java.util.*;
import java.util.stream.*;
import java.util.function.*;
import java.util.AbstractMap.SimpleEntry;

public class GroupByExample {
    public static void main(String[] args) {
        List<Person> people = Arrays.asList(
            new Person("Alice", 30),
            new Person("Bob", 25),
            new Person("Charlie", 30),
            new Person("David", 25),
            new Person("Eva", 40)
        );

        Map<Integer, Long> ageGroupCount = people.stream()
            .collect(Collectors.groupingBy(
                Person::getAge,
                Collectors.counting()
            ));

        System.out.println(ageGroupCount);
    }
}

在这个例子中,我们首先使用stream()方法将List<Person>转换为一个Stream。然后,我们使用collect()方法来收集结果。我们传递了一个Collectors.groupingBy()方法,它接受两个参数:一个用于分组的属性(在这里是Person::getAge),另一个用于计算每个分组的元素数量(在这里是Collectors.counting())。

运行这个程序,你将看到以下输出:

{25=2, 30=2, 40=1}

这表示年龄为25的人数有2人,年龄为30的人数有2人,年龄为40的人数有1人。这就是如何使用Java Stream进行分组统计的方法。

推荐阅读:
  1. 简洁方便的集合处理——Java 8 stream流
  2. JAVA8 STREAM COLLECT GROUPBY分组实例解析

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

java

上一篇:Stream如何实现中间操作与终端操作的区分

下一篇:Java Stream如何处理Stream中的异常

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》