Java8 Stream 流 多字段求和、汇聚

Stream 分组求和最终形态最终形态public static Map<String, Model> streamGroupSum(List<Model> datas){ return datas.stream().collect(Collectors.toMap(k -> k.getCode(), v -> v, (x, y) -> x.addCount().addAll(y))); }Model@Dataclass Model{
摘要由CSDN通过智能技术生成

实现方法

利用Collectors.toMap(Function keyMapper, Function valueMapper, BinaryOperator mergeFunction)
keyMapper:代表你最终想要获得的Map<Key, Value> 的Key
valueMapper:代表你最终想要获得的Map<Key, Value> 的Value
mergeFunction:表示碰到Key冲突是处理过程,{x, y}中x是已汇聚对象,y表示当前处理对象

对象类型数据处理

public static Map<String, Model> streamGroupSum(List<Model> datas){
   
    return datas.stream().collect(Collectors.toMap(k -> k.getCode(), v -> v, (x, y) -> x.addCount().addAll(y)));
  }

Model

@Data
class Model{
   
    private String code;
    private int count = 0;
    private Integer sum1;
    private Integer sum2;

    public Model(String code, Integer sum1, Integer sum2){
   
      this.code = code;
      this.sum1 = sum1;
      this.sum2 = sum2;
    }

    public Model addCount(){
   
      this.count++;
      return this;
    }
    
    public Model a
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据提供的引用内容,可以使用JavaStream来根据字段求和。首先,我们需要使用groupingBy方法对字段进行分组,然后使用reduce方法对每个组的值进行求和。以下是一个示例: ``` List<User> userList = new ArrayList<>(Arrays.asList( new User(1, new BigDecimal("10")), new User(2, new BigDecimal("100")), new User(3, new BigDecimal("50")) )); Map<Integer, BigDecimal> sumByUserId = userList.stream() .collect(Collectors.groupingBy(User::getId, Collectors.reducing(BigDecimal.ZERO, User::getMoney, BigDecimal::add))); ``` 在这个示例中,我们首先将用户列表转换为Stream。然后,使用groupingBy方法将用户按照ID进行分组。在reducing方法中,我们将初始值设置为BigDecimal.ZERO,将User对象的money字段作为累加器的操作,并使用BigDecimal的add方法将每个用户的money值相加。最后,我们将结果存储在一个Map中,其中键是用户的ID,值是对应用户的money求和结果。 请注意,这只是一个示例,你可以根据实际需修改代码来适应不同的场景。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [java中各种类型用Stream求和](https://blog.csdn.net/weixin_43296313/article/details/122600324)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [Java8 stream 中利用 groupingBy 进行多字段分组求和案例](https://download.csdn.net/download/weixin_38692928/12821045)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值