如何根据对象字段动态分组列表并生成嵌套子列表

发布时间 - 2026-01-31 00:00:00    点击率:

本文介绍如何基于 java stream api 和 collectors.groupingby,根据对象的指定字段(如 shape、size 或二者组合)将 list 动态划分为 list>,适用于多策略分组场景。

在实际开发中,常需根据业务类型(如 "type_1"、"type_2")对同一组对象执行不同维度的分组逻辑。核心需求是:给定一个 List,按 shape、size 或二者的联合值进行分组,最终返回 List>(即每个子列表包含具有相同分组键的对象)

✅ 基础分组:按单字段(如 shape)

使用 Collectors.groupingBy(Obj::getShape) 可将列表按 shape 字段归类为 Map>,再提取其 values() 并转为 ArrayList 即可:

public List> groupByShape(List objs) {
    return new ArrayList<>(objs.stream()
            .collect(Collectors.groupingBy(Obj::getShape))
            .values());
}
⚠️ 注意:确保 Obj 类已提供 getShape()(及 getSize())等标准 getter 方法;若字段为 private,缺少 getter 将导致编译错误。

✅ 扩展分组:按 size 或联合键(shape + size)

  • 按 size 分组:仅替换 key 提取器:

    .collect(Collectors.groupingBy(Obj::getSize))
  • 按 shape 和 size 联合分组(即唯一组合):推荐使用 AbstractMap.SimpleEntry 或自定义键类,但最简洁安全的方式是构造复合字符串键(需注意避免 shape="a_b" 与 size="c" 和 shape="a" 与 size="b_c" 的歧义)。更健壮的做法是使用 Record(Java 14+)或匿名内部类,但兼容性最佳的是 Map.entry(Java 9+):

public List> groupByShapeAndSize(List objs) {
    return new ArrayList<>(objs.stream()
            .collect(Collectors.groupingBy(
                obj -> Map.entry(obj.getShape(), obj.getSize())
            ))
            .values());
}

若使用 Java 8,可改用 Arrays.asList(obj.getShape(), obj.getSize()) 作为 key(需确保 shape/size 不为 null,否则抛 NPE):

.collect(Collectors.groupingBy(obj -> Arrays.asList(obj.getShape(), obj.getSize())))

✅ 整合进主函数:动态路由分组策略

将上述逻辑封装后,嵌入原 functionName 中,实现清晰可维护的分支处理:

public void functionName(Map> objMap) {
    objMap.forEach((type, objs) -> {
        List> groupedLists;
        switch (type) {
            case "type_1":
                groupedLists = groupByShape(objs);
                break;
            case "type_2":
                groupedLists = groupBySize(objs);
                break;
            case "type_3":
                groupedLists = groupByShapeAndSize(objs);
                break;
            default:
                groupedLists = Collections.singletonList(objs); // 不分组,保留原列表
        }
        // ✅ 此处对 groupedLists 进行后续业务处理(如统计、转换、持久化等)
 

processGroups(groupedLists); }); } private void processGroups(List> groups) { for (int i = 0; i < groups.size(); i++) { System.out.println("Group " + (i + 1) + ": " + groups.get(i)); } }

? 验证示例输出

以题设 "type_1" 输入为例:

[
  {"size":"m1","shape":"s1","name":"Obj_1"},
  {"size":"m2","shape":"s1","name":"Obj_2"},
  {"size":"m3","shape":"s2","name":"Obj_3"}
]

→ groupByShape 输出为:

[
  [Obj_1, Obj_2],  // shape="s1"
  [Obj_3]          // shape="s2"
]

完全符合预期。

✅ 总结

  • 核心工具:Stream.collect(Collectors.groupingBy(...)) 是实现动态分组的声明式首选;
  • 灵活性关键:通过函数式接口传入不同 key 提取器(Function),轻松切换分组维度;
  • 安全提示:确保 getter 方法存在且非空;联合分组时优先使用不可变结构(如 Map.entry 或 record)避免哈希冲突;
  • 性能友好:整个流程为单次流遍历,时间复杂度 O(n),无需额外嵌套循环。

该方案简洁、可读性强,且易于扩展新分组类型(如新增 "type_4" 按 name 首字母分组),是 Java 8+ 项目中处理条件分组任务的标准实践。


# java  # js  # 工具  # switch  # 路由  # stream  # 编译错误  # String  # NULL  # 封装  # 字符串  # 循环  # 接口  # private  # map  # function  # 对象  # 的是  # 遍历  # 推荐使用  # 适用于  # 自定义  # 为例  # 不为  # 可将  # 划分为  # 再提 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 敲碗10年!Mac系列传将迎来「触控与联网」双革新  Android利用动画实现背景逐渐变暗  如何彻底删除建站之星生成的Banner?  郑州企业网站制作公司,郑州招聘网站有哪些?  Laravel如何使用Service Container和依赖注入?(代码示例)  如何挑选高效建站主机与优质域名?  高端企业智能建站程序:SEO优化与响应式模板定制开发  Laravel安装步骤详细教程_Laravel环境搭建指南  Linux系统命令中screen命令详解  如何快速生成ASP一键建站模板并优化安全性?  长沙做网站要多少钱,长沙国安网络怎么样?  高防服务器租用指南:配置选择与快速部署攻略  网站优化排名时,需要考虑哪些问题呢?  北京专业网站制作设计师招聘,北京白云观官方网站?  哪家制作企业网站好,开办像阿里巴巴那样的网络公司和网站要怎么做?  Laravel怎么处理异常_Laravel自定义异常处理与错误页面教程  Windows Hello人脸识别突然无法使用  图片制作网站免费软件,有没有免费的网站或软件可以将图片批量转为A4大小的pdf?  PHP怎么接收前端传的文件路径_处理文件路径参数接收方法【汇总】  Laravel如何使用Guzzle调用外部接口_Laravel发起HTTP请求与JSON数据解析【详解】  javascript如何操作浏览器历史记录_怎样实现无刷新导航  重庆市网站制作公司,重庆招聘网站哪个好?  Laravel如何实现本地化和多语言支持_Laravel多语言配置与翻译文件管理  文字头像制作网站推荐软件,醒图能自动配文字吗?  Android滚轮选择时间控件使用详解  Laravel如何发送邮件_Laravel Mailables构建与发送邮件的简明教程  Laravel如何记录自定义日志?(Log频道配置)  如何在建站主机中优化服务器配置?  Laravel如何处理JSON字段的查询和更新_Laravel JSON列操作与查询技巧  如何用搬瓦工VPS快速搭建个人网站?  浅述节点的创建及常见功能的实现  Win11怎么修改DNS服务器 Win11设置DNS加速网络【指南】  Python函数文档自动校验_规范解析【教程】  C语言设计一个闪闪的圣诞树  网站制作大概要多少钱一个,做一个平台网站大概多少钱?  Laravel如何生成API文档?(Swagger/OpenAPI教程)  如何将凡科建站内容保存为本地文件?  Laravel的HTTP客户端怎么用_Laravel HTTP Client发起API请求教程  Laravel如何使用Collections进行数据处理?(实用方法示例)  DeepSeek是免费使用的吗 DeepSeek收费模式与Pro版本功能详解  php嵌入式断网后怎么恢复_php检测网络重连并恢复硬件控制【操作】  Thinkphp 中 distinct 的用法解析  Win11怎么关闭资讯和兴趣_Windows11任务栏设置隐藏小组件  网站页面设计需要考虑到这些问题  Laravel如何优雅地处理服务层_在Laravel中使用Service层和Repository层  Laravel如何使用Vite进行前端资源打包?(配置示例)  湖南网站制作公司,湖南上善若水科技有限公司做什么的?  如何在万网自助建站中设置域名及备案?  Laravel怎么清理缓存_Laravel optimize clear命令详解  高端网站建设与定制开发一站式解决方案 中企动力