Java循环:for、foreach与stream性能对比

33846371e7a712051394be0c7f325114.jpeg来源:juejin.cn/post/7302260568643256339

👉 欢迎加入小哈的星球,你将获得: 专属的项目实战 / 1v1 提问 / Java 学习路线 / 学习打卡 / 每月赠书 / 社群讨论

  • 新项目:《从零手撸:仿小红书(微服务架构)》 正在持续爆肝中,基于 Spring Cloud Alibaba + Spring Boot 3.x + JDK 17..., 点击查看项目介绍

  • 《从零手撸:前后端分离博客项目(全栈开发)》 2期已完结,演示链接:http://116.62.199.48/;

截止目前,累计输出 60w+ 字,讲解图 2330+ 张,还在持续爆肝中.. 后续还会上新更多项目,目标是将 Java 领域典型的项目都整一波,如秒杀系统, 在线商城, IM 即时通讯,Spring Cloud Alibaba 等等,戳我加入学习,解锁全部项目,已有2200+小伙伴加入

fec615973481aa8a9c670c3a41bd29a5.gif

性能比较

如果数据在1万以内的话,for循环效率高于foreach和stream;如果数据量在10万的时候,stream效率最高,其次是foreach,最后是for。

另外需要注意的是如果数据达到100万的话,parallelStream异步并行处理效率最高,高于foreach和for。

在效率方面,stream().forEach、forEach 和 parallelStream 之间存在一些差异。

stream().forEach:

在处理大量数据时,使用 stream().forEach 可能会比普通的 forEach 更高效。这是因为 stream().forEach 可以使用流式操作,对数据进行更优化的处理,例如通过并行流或者其他优化手段来提高处理速度。

但是需要注意的是,stream().forEach 也可能会引入一些额外的性能开销,比如流的创建和操作过程中的一些额外计算。

forEach:

forEach 方法是集合类的默认方法,它通常会按照集合内部的数据结构进行遍历,不涉及额外的流式操作或并行处理。因此,在某些情况下,forEach 可能会比 stream().forEach 更加高效。

parallelStream:

parallelStream 方法可以在处理大量数据时提供更高的效率,因为它可以利用多核处理器并行处理数据。在某些情况下,特别是对于需要并行处理的大型数据集合,使用 parallelStream 可能会比顺序处理更加高效。

然而,并行处理也可能引入一些额外的开销,比如线程调度、同步等,因此并不是所有情况下都适合使用 parallelStream

总的来说,对于数据量较小的情况,forEach 和 stream().forEach 的性能差异可能并不明显;而对于大型数据集合或需要并行处理的情况,考虑使用 parallelStream 可能会更加高效。在实际应用中,可以根据具体情况进行性能测试和选择合适的方法。

区别

在Java中,forEach 方法是用来对集合中的每个元素执行特定操作的方法。stream().forEach 和 forEach 方法都可以使用在集合类上,但是有一些区别。

stream().forEach:

stream().forEach 是针对 Stream 接口的方法,它通过创建一个流(Stream)来操作集合中的元素。这意味着它可以对集合进行更灵活的操作,比如筛选、映射和过滤等。

使用 stream().forEach 可以让操作变得更加函数式和流畅,可以方便地进行各种中间操作和终端操作。

forEach:

forEach 是 Iterable 接口中的默认方法,因此几乎所有的集合类都支持 forEach 方法。

forEach 方法是串行执行的,即对集合中的每个元素依次执行指定的操作。这意味着它不能并行处理集合中的元素。

parallelStream:

parallelStream 是 Collection 接口中新增的方法,它可以将集合转换成并行流,从而允许在多个线程上并行处理集合中的元素。

与普通的 stream() 方法相比,parallelStream 方法可以提高处理大量数据时的效率,因为它可以利用多核处理器并行处理数据。

因此,stream().forEach 提供了更多的灵活性和功能性,可以结合流式操作来对集合进行处理;而 forEach 和 parallelStream 则是集合类提供的简单遍历和并行处理的方法。

使用方式和行为

stream().forEach()forEach() 在使用方式和行为上有一些区别。

stream().forEach():

  • stream().forEach() 是流(Stream)API 的操作,用于对流中的每个元素执行给定的操作。

  • 它是一个终端操作,用于触发流的遍历和操作。

  • stream().forEach() 可以接收一个 lambda 表达式或方法引用作为参数,用于定义要执行的操作。

  • 它可以在串行流或并行流上执行操作,如果使用并行流,在多线程情况下可以实现更高的处理效率。

  • stream().forEach() 不保证元素的遍历顺序,可能是无序的。

forEach():

  • forEach() 是 Iterable 接口的默认方法,用于对集合中的每个元素执行给定的操作。

  • 它是一个终端操作,用于触发集合的遍历和操作。

  • forEach() 可以接收一个 lambda 表达式或方法引用作为参数,用于定义要执行的操作。

  • 它在单线程下按照集合的顺序依次遍历元素执行操作。

  • forEach() 保证按照集合元素的顺序执行操作,并且保持了元素的顺序性。

总体而言,stream().forEach() 主要用于流的操作,可以进行并行处理和无序遍历,适用于处理复杂的数据、并行操作和无序操作的场景。而 forEach() 则主要用于对集合进行遍历,并且保持了元素的顺序性,适用于简单的遍历操作。

fori

for (int i = 0; i < objects.size(); i++) {}

foreach

for (Object o : objects) {}

fori最普通的循环,可以时候得到当前的索引位置。

foreach 和fori区别不大,foreach是普通fori的增强版用起来更方便。但是没有当前索引。

list的遍历

方法一:itli  或者fori

for (int i = 0; i < list3.size(); i++) {
  Integer integer =  list3.get(i);
}

方法二:iter

for (Integer integer : list3) {
  
}

方法三:forEach

list.forEach(o->{});

方法四:stream().forEach

list.stream()
    .forEach(
        o -> {
        });

👉 欢迎加入小哈的星球,你将获得: 专属的项目实战 / 1v1 提问 / Java 学习路线 / 学习打卡 / 每月赠书 / 社群讨论

  • 新项目:《从零手撸:仿小红书(微服务架构)》 正在持续爆肝中,基于 Spring Cloud Alibaba + Spring Boot 3.x + JDK 17..., 点击查看项目介绍

  • 《从零手撸:前后端分离博客项目(全栈开发)》 2期已完结,演示链接:http://116.62.199.48/;

截止目前,累计输出 60w+ 字,讲解图 2330+ 张,还在持续爆肝中.. 后续还会上新更多项目,目标是将 Java 领域典型的项目都整一波,如秒杀系统, 在线商城, IM 即时通讯,Spring Cloud Alibaba 等等,戳我加入学习,解锁全部项目,已有2200+小伙伴加入

b0f58a243439614a5cb08272b1f0c6de.gif

366bb4b99c4be4fd32efbb0dc29b404d.jpeg

 
 

156520ab2ba53e92adf51d07408c28ad.gif

 
 
 
 
1. 我的私密学习小圈子~
2. 动态切换实现类框架,快看看 Spring-Smart-DI 是不是你的菜?
3. 警告!请勿过度依赖 Redis 的过期监听
4. SpringBoot实现电子文件签字+合同系统!
 
 
最近面试BAT,整理一份面试资料《Java面试BATJ通关手册》,覆盖了Java核心技术、JVM、Java并发、SSM、微服务、数据库、数据结构等等。
获取方式:点“在看”,关注公众号并回复 Java 领取,更多内容陆续奉上。
PS:因公众号平台更改了推送规则,如果不想错过内容,记得读完点一下“在看”,加个“星标”,这样每次新文章推送才会第一时间出现在你的订阅列表里。
点“在看”支持小哈呀,谢谢啦
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值