Collectors.groupingBy分组后乱序问题

简介: Collectors.groupingBy分组后乱序问题

问题描述:

当我们对List根据时间排序,然后根据某个字段分组后,会产生乱序的问题。

解决办法:

因为Collectors.groupingBy分组后默认返回HashMap类型,我们修改为LinkedHashMap即可。


Collectors.groupingBy部分源码:


//一个参数 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即可。


样例:


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分组后乱序问题的全部内容

相关文章
|
7月前
JDK8之stream流的使用:分组
JDK8之stream流的使用:分组
289 0
|
3月前
如何优雅地对数据进行分组?
如何优雅地对数据进行分组?
36 0
|
7月前
使用lamba中stream 进行分组统计
使用lamba中stream 进行分组统计
|
Java
stream流分组
stream流分组
91 0
|
C#
C# distnict去重
C# distnict去重
79 0
Stream操作之 先分组再取最大值
Stream操作之 先分组再取最大值
550 0
|
关系型数据库
分组
GROUP BY 语句根据一个或多个列对结果集进行分组。
|
算法 搜索推荐
用函数的方法通过冒泡法实现对一个数组(乱序)到有序排序(由大到小排序)
用函数的方法通过冒泡法实现对一个数组(乱序)到有序排序(由大到小排序)
111 0
用函数的方法通过冒泡法实现对一个数组(乱序)到有序排序(由大到小排序)