使用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
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Geek-Banana

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

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

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

打赏作者

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

抵扣说明:

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

余额充值