国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

java-ee - java8的Collectors.reducing()

瀏覽:85日期:2023-10-18 15:09:42

問題描述

Map<Integer, OperationCountVO> collect = operationInfos.stream().collect(Collectors.groupingBy(OperationCountVO::getCityId, Collectors.reducing(new OperationCountVO(), (OperationCountVO v1, OperationCountVO v2) -> {v1.setSurgeryCount(v1.getSurgeryCount() + v2.getSurgeryCount());v1.setCityId(v2.getCityId());return v1; })));

大概就是我想對operationInfos集合按照里面的cityId進行分組,然后cityId一樣的話,把對象的SurgeryCount加起來返回,但是現(xiàn)在 第一次的v1是null,執(zhí)行v1.setSurgeryCount(v1.getSurgeryCount() + v2.getSurgeryCount());的時候報了空指針,我哪里寫的有問題嗎?

問題解答

回答1:

若v1是null的話,那就說明operationInfos集合里面是有null的,因為是要根據(jù)OperationCountVO的cityId進行分組,那OperationCountVO一定不為null,建議前面直接加filter過濾掉

Map<Integer, OperationCountVO> collect = operationInfos.stream().filter(Objects::nonNull).collect(Collectors.groupingBy(OperationCountVO::getCityId, Collectors.reducing(new OperationCountVO(), (OperationCountVO v1, OperationCountVO v2) -> {v1.setSurgeryCount(v1.getSurgeryCount() + v2.getSurgeryCount());v1.setCityId(v2.getCityId());return v1; })));

剛評論發(fā)現(xiàn)...可能報錯原因還有可能是,Collectors.reducing中的第一個參數(shù)為new OperationCountVO(),若new出來的OperationCountVO對象的surgeryCount為Integer類型,不是基本類型的話,所以沒有初始化,surgeryCount就為null,在做v1.getSurgeryCount() + v2.getSurgeryCount()操作的時候就可能報錯了呀

(ps:對于reducing中的第二個參數(shù)BinaryOperator,最好還是封裝到OperationCountVO對象中,看起來代碼更聲明式一點...這樣寫代碼太丑了...哈哈...或者寫出來,寫成一個靜態(tài)final變量更好,到時候可以到處調(diào)用嘛)

比如直接在本類上新增一個SurgeryCount屬性合并的BinaryOperator,名字就叫surgeryCountMerge

public static final BinaryOperator<OperationCountVO> surgeryCountMerge = (v1, v2) -> { v1.setSurgeryCount(v1.getSurgeryCount() + v2.getSurgeryCount()); return v1;}

這樣下面代碼就可以改成

Map<Integer, OperationCountVO> collect = operationInfos.stream().filter(Objects::nonNull).collect(Collectors.groupingBy(OperationCountVO::getCityId,Collectors.reducing(new OperationCountVO(), surgeryCountMerge));

這樣寫了之后,其實發(fā)現(xiàn)題主可能做麻煩了點,最后不就是為了返回一個Map嘛,所以建議不使用groupingBy,畢竟分組返回結果是一對多這樣的結構,不是一對一的結構,那直接使用toMap嘛,直接點

Map<Integer, OperationCountVO> collect = operationInfos.stream().filter(Objects::nonNull).collect(Collectors.toMap(OperationCountVO::getCityId, Function.identity(), surgeryCountMerge));

這樣快多了噻,還不會報錯,哈哈

標簽: java
相關文章:
主站蜘蛛池模板: 99久久国产综合精品国 | 中文字幕乱码中文乱码51精品 | 欧美精品国产一区二区三区 | 国内精品伊人久久久影视 | 精品国产自在现线看久久 | 国产男女 爽爽爽爽视频 | 亚洲欧美日韩久久一区 | 国内自拍视频在线播放 | 成人国产三级精品 | 免费看成人播放毛片 | 性理论片 | 日韩欧美视频一区二区三区 | 国内一级特黄女人精品片 | 狠狠色丁香婷婷综合久久片 | 波多野结衣免费视频观看 | 精品免费久久久久久成人影院 | 成人免费一区二区三区视频软件 | 久久99热精品免费观看k影院 | 看久久久久毛片婷婷色 | a级片免费观看视频 | 日本xxxxx久色视频在线观看 | 亚洲免费视频网址 | 久久国产免费观看精品1 | 亚洲精品网址 | 精品视频一区二区三区免费 | 91成人国产| 久久视屏这里只有精品6国产 | 97香蕉久久夜色精品国产 | 成人一级片在线观看 | 亚洲成人国产精品 | 亚洲手机国产精品 | 亚洲精品综合一区二区三区 | 成人香蕉视频 | 黄色一级片在线看 | 亚洲一级理论片 | 国产一区二区三区久久小说 | 三级毛片免费看 | 久久久久久久久久久9精品视频 | 日韩一级欧美一级毛片在线 | 国产一级真人毛爱做毛片 | 久久综合精品视频 |