// 后台设置的渠道 String channelNo = channelDao.getOne().getChannelNo(); // 第三方拉取的数据 List<ThirdData> thirdDataList = httpClientUtils.getThirdDatas(DateUtils.today()); // 匹配过滤 thirdDataList.stream().filter(o ->channelNo.equals(o.getChannelNo())).collect(Collectors.toList()); // 批量入库 thirdDataDao.saveAll(thirdDataList);
上述四行代码的问题修复
1.如果channelDao.getOne()为null会报错
解决方案:
1、使用防御性编程,提前返回(需根据具体业务场景而定)
// 如果channelNo是方法逻辑执行的必须元素,推荐用此方法 Channel channel = channelDao.getOne(); if (channel == null) { return; }
2.使用三目运算
tring channelNo = channelDao.getOne() == null ? "" : channelDao.getOne().getChannelNo();
3.使用optionan函数返回空字符串
String channelNo = Optional.ofNullable(channelDao.getOne()).orElse("");
2.thirdDateList如果为空,也会报错 channelNo如果返回为null,那么执行channelNo.equals(o.getChannelNo())会报NPE
解决方案:
1.使用防御性编程,提前返回
if (CollectionUtils.isEmpty(thirdDataList)) { return; }
2.使用object下的
Objects.equals(channelNo, o.getChannelNo())
ObjectUtils.nullSafeEquals(o1,o2)
标签:getChannelNo,channelDao,NPE,解决方案,thirdDataList,getOne,channelNo,null From: https://www.cnblogs.com/jerry-ming/p/16648304.html