JDK8 的排序、分组求和,转换为Map

👌明白了,你想要的核心是:

  1. 排序
  2. 分组求和
  3. 转换为 Map

下面我写一个完整的 JDK8 示例,包含这三类常用操作。


示例代码

java 复制代码
import java.util.*;
import java.util.stream.Collectors;

class Person {
    String name;
    String city;
    int age;
    int salary;

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

    @Override
    public String toString() {
        return name + "-" + city + "-" + age + "-" + salary;
    }
}

public class StreamDemo {
    public static void main(String[] args) {
        List<Person> people = Arrays.asList(
                new Person("Tom", "Beijing", 20, 5000),
                new Person("Jerry", "Shanghai", 25, 7000),
                new Person("Alice", "Beijing", 30, 8000),
                new Person("Bob", "Shanghai", 18, 4000),
                new Person("Lily", "Beijing", 28, 6000)
        );

        // 1. 排序:按工资降序
        List<Person> sortedBySalary = people.stream()
                .sorted(Comparator.comparingInt((Person p) -> p.salary).reversed())
                .collect(Collectors.toList());
        System.out.println("按工资降序排序:" + sortedBySalary);

        // 2. 分组求和:按城市分组,统计总工资
        Map<String, Integer> salarySumByCity = people.stream()
                .collect(Collectors.groupingBy(
                        p -> p.city,
                        Collectors.summingInt(p -> p.salary)
                ));
        System.out.println("按城市统计工资总和:" + salarySumByCity);

        // 3. 转换为 Map:姓名 -> 工资
        Map<String, Integer> nameToSalary = people.stream()
                .collect(Collectors.toMap(p -> p.name, p -> p.salary));
        System.out.println("姓名 -> 工资:" + nameToSalary);

        // 4. 如果 key 可能重复(比如按城市转 Map),需要指定合并规则
        Map<String, Integer> cityToSalary = people.stream()
                .collect(Collectors.toMap(
                        p -> p.city,
                        p -> p.salary,
                        Integer::sum   // key 冲突时,合并 value(工资相加)
                ));
        System.out.println("城市 -> 工资总和 (toMap 实现):" + cityToSalary);
    }
}

输出结果示例

复制代码
按工资降序排序:[Alice-Beijing-30-8000, Jerry-Shanghai-25-7000, Lily-Beijing-28-6000, Tom-Beijing-20-5000, Bob-Shanghai-18-4000]
按城市统计工资总和:{Beijing=19000, Shanghai=11000}
姓名 -> 工资:{Alice=8000, Bob=4000, Jerry=7000, Tom=5000, Lily=6000}
城市 -> 工资总和 (toMap 实现):{Beijing=19000, Shanghai=11000}

✅ 总结:

  • 排序sorted(Comparator.comparingInt(...).reversed())
  • 分组求和Collectors.groupingBy(..., Collectors.summingInt(...))
  • 转换为 MapCollectors.toMap(key, value, mergeFunction)

要不要我帮你写一个更贴近业务表数据的版本(比如订单表:用户、商品、金额,做排序+分组求和+转 Map)?这样会更像实际开发中的用法。

相关推荐
m0_481147332 分钟前
拦截器跟过滤器的区别?拦截器需要注册吗?过滤器需要注册吗?
java
lili-felicity4 分钟前
CANN性能调优与实战问题排查:从基础优化到排障工具落地
开发语言·人工智能
Coder_Boy_6 分钟前
基于SpringAI的在线考试系统-相关技术栈(分布式场景下事件机制)
java·spring boot·分布式·ddd
独自破碎E7 分钟前
【BISHI15】小红的夹吃棋
android·java·开发语言
冻感糕人~8 分钟前
【珍藏必备】ReAct框架实战指南:从零开始构建AI智能体,让大模型学会思考与行动
java·前端·人工智能·react.js·大模型·就业·大模型学习
啦啦啦_999914 分钟前
Redis实例-2
java
alice--小文子19 分钟前
cursor-mcp工具使用
java·服务器·前端
进阶小白猿19 分钟前
Java技术八股学习Day33
java·开发语言·学习
程序员敲代码吗25 分钟前
如何通过命令行启动COMSOL的参数化、批处理和集群扫描
java·c#·bash
MX_935930 分钟前
Spring的bean工厂后处理器和Bean后处理器
java·后端·spring