stream的Collectors.groupingBy()方法的大坑

1.前言

  • 在开发过程中,java8流行的stream流非常的好用,简化代码,又容易读懂,但是它有一个大炕。

2. 大坑重现

  • 当list集合里某个元素的属性为空,并且你使用Collectors.groupingBy()方法对这个属性进行分组,这时系统会报错。
List<DTO> list = Lists.newArrayList();
for(int i=0;i<5;i++){
     DTO dto = new DTO();
     dto.setCode("code"+i);
     if(i==0||i==4){
         dto.setCenterRandomSysId(null);
     }else {
         dto.setCenterRandomSysId("111");
     }
     list.add(dto);
 }
 
Map<String, List<DTO>> map = list.stream().collect(Collectors.groupingBy(DTO::getCenterRandomSysId)); //大坑出现,这里会报错
System.out.println(map);
  • 执行结果

Exception in thread “main” java.lang.NullPointerException: element cannot be mapped to a null key

3. 解决方法

  • 解决它也很简单,在分组之前加一个过滤操作
List<DTO> list = Lists.newArrayList();
for(int i=0;i<5;i++){
     DTO dto = new DTO();
     dto.setCode("code"+i);
     if(i==0||i==4){
         dto.setCenterRandomSysId(null);
     }else {
         dto.setCenterRandomSysId("111");
     }
     list.add(dto);
 }
 
Map<String, List<DTO>> map = list.stream()
		.filter(dto-> StringUtils.isNotBlank(dto.getCenterRandomSysId()))
		.collect(Collectors.groupingBy(DTO::getCenterRandomSysId)); //大坑出现,这里会报错
System.out.println(map);
  • 执行结果

{111=[{“centerRandomSysId”:“111”,“code”:“code1”}, {“centerRandomSysId”:“111”,“code”:“code2”}, {“centerRandomSysId”:“111”,“code”:“code3”}]}

  • 4
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值