JAVA8 对List分组同时排好序

public ResponseStatus findAllFkRuleByFsId(String fsId) {
    List<FkRule> fkRuleList = fkRuleRepository.findAllByFsIdAndStatusIsNotOrderBySort(fsId, -1);
    //查询列表规则编号分组同时排好序,根据实体FkRule 的code分组,同时,创建LinkedHashMap 容器。这样能保证
插入的顺序,和取出的顺序一样,

    LinkedHashMap<String, List<FkRule>> groupBy = fkRuleList.stream().collect(Collectors.groupingBy
        (FkRule::getCode,LinkedHashMap::new,Collectors.toList()));

    List<FkRuleVO> fkRuleVOList = new ArrayList<>();

    for (Map.Entry<String, List<FkRule>> entry : groupBy.entrySet()) {
        FkRuleVO fkRuleVO = new FkRuleVO();
        fkRuleVO.setCode(entry.getKey());
        fkRuleVO.setFkRuleList(entry.getValue());
        fkRuleVOList.add(fkRuleVO);
    }

    return ResponseStatus.object(fkRuleVOList);
}

 

下面是groupingBy的参数说明

 

可以看到有三个参数,第一个参数就是key的Function了,第二个参数是一个map工厂,也就是最终结果的容器,一般默认的是采用的HashMap::new,最后一个参数很重要是一个downstream,类型是Collector,也是一个收集器,那就是说,这三个参数其实就是为了解决分组问题的

  1. 第一个参数:分组按照什么分类

  2. 第二个参数:分组最后用什么容器保存返回

  3. 第三个参数:按照第一个参数分类后,对应的分类的结果如何收集

 

其实一个参数的Collectors.groupingBy方法的 ,第二个参数默认是HashMap::new, 第三个参数收集器其实默认是Collectors.toList

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值