Java条件组合问题_Java-合并给定条件的列表对象

小编典典

您可以创建一个包含三个字段的键类,例如

@Data

class UserKey {

String firstName;

String lastName;

String type;

static UserKey from(User user) { /* TODO (trivial) */ }

}

分组

这些可以用来对您的用户进行分组

Map> grouped =

users.stream().collect(Collectors.groupingBy(UserKey::from));

这些列表中的每一个都可以通过合并

Optional summed = userList.stream()

.collect(Collectors.reducing((u1, u2) -> {

u1.setAccountBalance(u1.accountBalance() + u2.accountBalance());

});

也可以直接将其作为下游收集器提供给groupingBy:

Map> mergedMap =

users.stream().collect(Collectors.groupingBy(UserKey::from,

Collectors.reducing((u1, u2) -> {

u1.setAccountBalance(u1.accountBalance() + u2.accountBalance());

return u1;

}));

由于Optional可以确保已填充了这些,因此您可以调用get()它们;而且,您不再需要按键,因此

List result = mergedMap.values().stream()

.map(Optional::get)

.collect(toList());

地图

就像Naman在评论中建议的那样,您也可以通过快捷方式toMap。

Map mergedMap = users.stream()

.collect(toMap(UserKey::from, Function.identity(),

(u1, u2) -> {

u1.setAccountBalance(u1.accountBalance() + u2.accountBalance());

return u1;

}));

List result = new ArrayList<>(mergedMap.values());

请注意,reduce函数具有操作列表中原始用户对象之一的副作用,因此请确保不再需要它们。

2020-11-26

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值