问题描述:
当我们对List根据时间排序,然后根据某个字段分组后,会产生乱序的问题。
解决办法:
因为Collectors.groupingBy分组后默认返回HashMap类型,我们修改为linkedHashMap即可。
Collectors.groupingBy部分源码:
//一个参数 classifier public staticCollector >> groupingBy(Function super T, ? extends K> classifier) { return groupingBy(classifier, toList()); } //两个参数 classifier 和 downstream public static Collector > groupingBy(Function super T, ? extends K> classifier, Collector super T, A, D> downstream) { return groupingBy(classifier, HashMap::new, downstream); } //三个参数 classifier 和 mapFactory 和 downstream public static > Collector groupingBy(Function super T, ? extends K> classifier, Supplier mapFactory, Collector super T, A, D> downstream) {..}
通过源码可以看到,我们可以上传三个参数,分别是:
classifier:按照什么分组
mapFactory:最后的结果返回的容器
downstream:收集分类的结果的收集器
当我们只上传一个参数后,默认第二个参数downstream是HashMap::new,也就是返回结果用HashMap存储,我们想返回HashMap就需要调用三个参数的方法,自定义downstream为linkedHashMap::new即可。
样例:
linkedHashMap> 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



