专栏名称: 芋道源码
纯 Java 源码分享公众号,目前有「Dubbo」「SpringCloud」「Java 并发」「RocketMQ」「Sharding-JDBC」「MyCAT」「Elastic-Job」「SkyWalking」「Spring」等等
目录
相关文章推荐
芋道源码  ·  SpringBoot + ... ·  3 天前  
Java编程精选  ·  网友感叹:事业编一年6万,干40年退休总共挣 ... ·  5 天前  
芋道源码  ·  Seata+TCC 解决分布式事务,真香! ·  3 天前  
芋道源码  ·  MySQL一键巡检脚本!再也不用自己梳理了 ·  6 天前  
芋道源码  ·  SpringBoot控制层中,@Servic ... ·  6 天前  
51好读  ›  专栏  ›  芋道源码

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

芋道源码  · 公众号  · Java  · 2024-10-26 10:54

正文

👉 这是一个或许对你有用的社群

🐱 一对一交流/面试小册/简历优化/求职解惑,欢迎加入芋道快速开发平台知识星球。下面是星球提供的部分资料: 

👉这是一个或许对你有用的开源项目

国产 Star 破 10w+ 的开源项目,前端包括管理后台 + 微信小程序,后端支持单体和微服务架构。

功能涵盖 RBAC 权限、SaaS 多租户、数据权限、商城、支付、工作流、大屏报表、微信公众号、CRM 等等功能:

  • Boot 仓库:https://gitee.com/zhijiantianya/ruoyi-vue-pro
  • Cloud 仓库:https://gitee.com/zhijiantianya/yudao-cloud
  • 视频教程:https://doc.iocoder.cn
【国内首批】支持 JDK 21 + SpringBoot 3.2.2、JDK 8 + Spring Boot 2.7.18 双版本 

来源:juejin.cn/post/
7302260568643256339


性能比较

如果数据在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 可能会更加高效。在实际应用中,可以根据具体情况进行性能测试和选择合适的方法。

基于 Spring Boot + MyBatis Plus + Vue & Element 实现的后台管理系统 + 用户小程序,支持 RBAC 动态权限、多租户、数据权限、工作流、三方登录、支付、短信、商城等功能

  • 项目地址:https://github.com/YunaiV/ruoyi-vue-pro
  • 视频教程:https://doc.iocoder.cn/video/

区别

在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 

foreach

for (Object o : objects) {}

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

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

list的遍历

方法一:itli  或者fori

for (int i = 0; i   Integer integer =  list3.get(i);
}

方法二:iter

for (Integer integer : list3) {
  
}

方法三:forEach

list.forEach(o->{});

方法四:stream().forEach

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

欢迎加入我的知识星球,全面提升技术能力。

👉 加入方式,长按”或“扫描”下方二维码噢

星球的内容包括:项目实战、面试招聘、源码解析、学习路线。

文章有帮助的话,在看,转发吧。

谢谢支持哟 (*^__^*)