前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >collectors.groupingby属性分组_group by having order by

collectors.groupingby属性分组_group by having order by

作者头像
全栈程序员站长
发布2022-09-23 10:21:36
5680
发布2022-09-23 10:21:36
举报
文章被收录于专栏:全栈程序员必看

大家好,又见面了,我是你们的朋友全栈君。

问题描述: 当我们对List根据时间排序,然后根据某个字段分组后,会产生乱序的问题。 解决办法: 因为Collectors.groupingBy分组后默认返回HashMap类型,我们修改为LinkedHashMap即可。

Collectors.groupingBy部分源码:

代码语言:javascript
复制
//一个参数 classifier
public static <T, K> Collector<T, ?, Map<K, List<T>>>
groupingBy(Function<? super T, ? extends K> classifier) { 
   
    return groupingBy(classifier, toList());
}

//两个参数 classifier 和 downstream
public static <T, K, A, D>
    Collector<T, ?, Map<K, D>> groupingBy(Function<? super T, ? extends K> classifier,
                                          Collector<? super T, A, D> downstream) { 
   
    return groupingBy(classifier, HashMap::new, downstream);
}

//三个参数 classifier 和 mapFactory 和 downstream
public static <T, K, D, A, M extends Map<K, D>>
    Collector<T, ?, M> groupingBy(Function<? super T, ? extends K> classifier,
                                  Supplier<M> mapFactory,
                                  Collector<? super T, A, D> downstream) { 
   ..}

通过源码可以看到,我们可以上传三个参数,分别是: classifier:按照什么分组 mapFactory:最后的结果返回的容器 downstream:收集分类的结果的收集器 当我们只上传一个参数后,默认第二个参数downstream是HashMap::new,也就是返回结果用HashMap存储,我们想返回HashMap就需要调用三个参数的方法,自定义downstream为LinkedHashMap::new即可。

样例:

代码语言:javascript
复制
LinkedHashMap<String,List<ProcessDetails>> resultSort;

//根据开始日期排序, groupBy字段分组返回类型修改为LinkedHashMap,否则乱序
resultSort = result
        .stream()
        .sorted(Comparator.comparing(ProcessDetails::getBeginTime))
        .collect(Collectors.groupingBy(ProcessDetails::getGroupBy,LinkedHashMap::new,Collectors.toList()));

以上就是Collectors.groupingBy分组后乱序问题的全部内容

版权声明: 原创博主:牛哄哄的柯南 博主原文链接:https://keafmd.blog.csdn.net/

看完如果对你有帮助,感谢点击下面的一键三连支持! [哈哈][抱拳]

请添加图片描述
请添加图片描述
在这里插入图片描述
在这里插入图片描述

加油!

共同努力!

Keafmd

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/171407.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档