java8 lambada使用Collectors.groupingBy分组顺序错误
最近有个需求就是按照LocalDate分组排序但是一直数据都是错乱的,后来查了资料可以看到有三个参数,第一个参数就是key的Function了,第二个参数是一个map工厂,也就是最终结果的容器,一般默认的是采用的HashMap::new,最后一个参数很重要是一个downstream,类型是Collector,也是一个收集器,那就是说,这三个参数其实就是为了解决分组问题的第一个参数:分组...
·
最近有个需求就是按照LocalDate分组排序但是一直数据都是错乱的,后来查了资料
可以看到有三个参数,第一个参数就是key的Function
了,第二个参数是一个map工厂,也就是最终结果的容器,一般默认的是采用的HashMap::new
,最后一个参数很重要是一个downstream
,类型是Collector
,也是一个收集器,那就是说,这三个参数其实就是为了解决分组问题的
-
第一个参数:分组按照什么分类
-
第二个参数:分组最后用什么容器保存返回
-
第三个参数:按照第一个参数分类后,对应的分类的结果如何收集
其实一个参数的Collectors.groupingBy
方法的 ,第二个参数默认是HashMap::new
, 第三个参数收集器其实默认是Collectors.toList
所以HashMap是无序的大家都是知道的,所以原因找到了。
Map<LocalDate, List<Model>> modelMap = modelVOList.stream().collect(Collectors.groupingBy(Model::getGroupTime, LinkedHashMap::new, Collectors.toList()));
完美解决
更多推荐
已为社区贡献1条内容
所有评论(0)