JAVA使用stream对数据分组后求每组的最大值

JAVA stream对数据分组后求每组的最大值
具体需求

对industryCode分组,然后通过取出每组的num的最大值

// 实体类
@Data
@AllArgsConstructor
public class IndustryStockRelation {
    private Long id;
    private String industryCode;
    private Integer num;
}
// 具体实现
public static void main(String[] args) {
	List<IndustryStockRelation> industryStockRelationList = new LinkedList<>();
	        IndustryStockRelation i1 = new IndustryStockRelation(1L,"100720401",3);
	        IndustryStockRelation i2 = new IndustryStockRelation(2L,"100720402",6);
	        IndustryStockRelation i3 = new IndustryStockRelation(2L,"100720401",9);
	        IndustryStockRelation i4 = new IndustryStockRelation(3L,"100720403",6);
	        industryStockRelationList.add(i1);
	        industryStockRelationList.add(i2);
	        industryStockRelationList.add(i3);
	        industryStockRelationList.add(i4);
	        Map<String,IndustryStockRelation> map =
	                industryStockRelationList.parallelStream().collect(
	                        Collectors.groupingBy(IndustryStockRelation::getIndustryCode,
	                                Collectors.collectingAndThen(
	                                        Collectors.reducing((a,b)->a.getNum()> b.getNum()?a:b),Optional::get)
	
	                        )
	                );
}
// 结果
{
100720402=IndustryStockRelation(id=2, industryCode=100720402, num=6), 
100720403=IndustryStockRelation(id=3, industryCode=100720403, num=6), 
100720401=IndustryStockRelation(id=2, industryCode=100720401, num=9)
}
  • 5
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值