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