使用java中的stream,嵌套list根据实体某个字段求和

嵌套list求和,如题

记录一下,搞了半天,积累一下,后续写stream整套的文章

for循环解决

int sum = 0;
for (EntityA entityA : list) {
    for (EntityB entityB : entityA.getEntityBList()) {
        sum += entityB.getCount();
    }
}

用stream流解决

int res = list.stream().map(EntityA::getEntityBList)
        .map(item -> item.stream().map(EntityB::getCount).reduce(0, Integer::sum))
        .reduce(0, Integer::sum);

不过,对于性能有待考究,我觉的流应该比for循环要快,但是相比较速度更慢,我还是觉得有些奇怪

我的测试数据如下:

数据量使用for循环解决的时间使用stream流解决的时间
101ms80ms
1001ms85ms
10003ms84ms
1000010ms94ms
100_00025ms122ms
1_000_000125ms413ms
10_000_0001133ms3164ms
Java 8的Stream,可以使用groupingBy方法进行多字段分组求和。首先,我们需要创建一个包含对象的集合,然后使用stream方法将其转换为流。接下来,我们可以使用groupingBy方法来指定多个字段作为分组条件。每个字段都可以通过lambda表达式来指定。最后,我们可以使用collect方法来收集结果。 示例代码如下: ``` List<Item> items = Arrays.asList( new Item("apple", "China"), new Item("apple", "USA"), new Item("banana", "China"), new Item("banana", "USA"), new Item("orange", "China"), new Item("orange", "USA") ); Map<String, Map<String, Long>> result = items.stream() .collect(Collectors.groupingBy(Item::getProductType, Collectors.groupingBy(Item::getCountry, Collectors.counting()))); System.out.println(result); ``` 在这个示例,我们创建了一个包含产品类型和国家的Item对象集合。然后,我们使用stream方法将其转换为流。接下来,我们使用groupingBy方法指定了两个字段作为分组条件,即产品类型和国家。最后,我们使用collect方法来收集结果,并将结果存储在一个嵌套的Map,其外层的键是产品类型,内层的键是国家,值是对应的计数。 输出结果将会是一个嵌套的Map,其外层的键是产品类型,内层的键是国家,值是对应的计数。 #### 引用[.reference_title] - *1* *3* [Java8 stream 利用 groupingBy 进行多字段分组求和](https://blog.csdn.net/lizhengyu891231/article/details/108997080)[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^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [Java8 stream 利用 groupingBy 进行多字段分组](https://blog.csdn.net/weixin_39637363/article/details/113543899)[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^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Geek-Banana

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值