Java中for、foreach、stream区别和性能比较

文章目录

性能比较

最终总结:如果数据在1万以内的话,for循环效率高于foreach和stream;如果数据量在10万的时候,stream效率最高,其次是foreach,最后是for。另外需要注意的是如果数据达到100万的话,parallelStream异步并行处理效率最高,高于foreach和for。

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

  1. stream().forEach:
    ○ 在处理大量数据时,使用 stream().forEach 可能会比普通的 forEach 更高效。这是因为 stream().forEach 可以使用流式操作,对数据进行更优化的处理,例如通过并行流或者其他优化手段来提高处理速度。
    ○ 但是需要注意的是,stream().forEach 也可能会引入一些额外的性能开销,比如流的创建和操作过程中的一些额外计算。
  2. forEach:
    ○ forEach 方法是集合类的默认方法,它通常会按照集合内部的数据结构进行遍历,不涉及额外的流式操作或并行处理。因此,在某些情况下,forEach 可能会比 stream().forEach 更加高效。
  3. parallelStream:
    ○ parallelStream 方法可以在处理大量数据时提供更高的效率,因为它可以利用多核处理器并行处理数据。在某些情况下,特别是对于需要并行处理的大型数据集合,使用 parallelStream 可能会比顺序处理更加高效。
    ○ 然而,并行处理也可能引入一些额外的开销,比如线程调度、同步等,因此并不是所有情况下都适合使用 parallelStream。
    总的来说,对于数据量较小的情况,forEach 和 stream().forEach 的性能差异可能并不明显;而对于大型数据集合或需要并行处理的情况,考虑使用 parallelStream 可能会更加高效。在实际应用中,可以根据具体情况进行性能测试和选择合适的方法。

区别

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

  1. stream().forEach:
    ○ stream().forEach 是针对 Stream 接口的方法,它通过创建一个流(Stream)来操作集合中的元素。这意味着它可以对集合进行更灵活的操作,比如筛选、映射和过滤等。
    ○ 使用 stream().forEach 可以让操作变得更加函数式和流畅,可以方便地进行各种中间操作和终端操作。
  2. forEach:
    ○ forEach 是 Iterable 接口中的默认方法,因此几乎所有的集合类都支持 forEach 方法。
    ○ forEach 方法是串行执行的,即对集合中的每个元素依次执行指定的操作。这意味着它不能并行处理集合中的元素。
  3. parallelStream:
    ○ parallelStream 是 Collection 接口中新增的方法,它可以将集合转换成并行流,从而允许在多个线程上并行处理集合中的元素。
    ○ 与普通的 stream() 方法相比,parallelStream 方法可以提高处理大量数据时的效率,因为它可以利用多核处理器并行处理数据。
    因此,stream().forEach 提供了更多的灵活性和功能性,可以结合流式操作来对集合进行处理;而 forEach 和 parallelStream 则是集合类提供的简单遍历和并行处理的方法。

使用方式和行为

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

  1. stream().forEach():
    ○ stream().forEach() 是流(Stream)API 的操作,用于对流中的每个元素执行给定的操作。
    ○ 它是一个终端操作,用于触发流的遍历和操作。
    ○ stream().forEach() 可以接收一个 lambda 表达式或方法引用作为参数,用于定义要执行的操作。
    ○ 它可以在串行流或并行流上执行操作,如果使用并行流,在多线程情况下可以实现更高的处理效率。
    ○ stream().forEach() 不保证元素的遍历顺序,可能是无序的。
  2. forEach():
    ○ forEach() 是 Iterable 接口的默认方法,用于对集合中的每个元素执行给定的操作。
    ○ 它是一个终端操作,用于触发集合的遍历和操作。
    ○ forEach() 可以接收一个 lambda 表达式或方法引用作为参数,用于定义要执行的操作。
    ○ 它在单线程下按照集合的顺序依次遍历元素执行操作。
    ○ forEach() 保证按照集合元素的顺序执行操作,并且保持了元素的顺序性。
    总体而言,stream().forEach() 主要用于流的操作,可以进行并行处理和无序遍历,适用于处理复杂的数据、并行操作和无序操作的场景。而 forEach() 则主要用于对集合进行遍历,并且保持了元素的顺序性,适用于简单的遍历操作。
java 复制代码
fori
for (int i = 0; i < objects.size(); i++) {}
foreach
for (Object o : objects) {}
fori最普通的循环,可以时候得到当前的索引位置。
 
foreach 和fori区别不大,foreach是普通fori的增强版用起来更方便。但是没有当前索引。
java 复制代码
1.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 -> {
        });
相关推荐
腥臭腐朽的日子熠熠生辉23 分钟前
解决maven失效问题(现象:maven中只有jdk的工具包,没有springboot的包)
java·spring boot·maven
ejinxian24 分钟前
Spring AI Alibaba 快速开发生成式 Java AI 应用
java·人工智能·spring
杉之30 分钟前
SpringBlade 数据库字段的自动填充
java·笔记·学习·spring·tomcat
圈圈编码1 小时前
Spring Task 定时任务
java·前端·spring
俏布斯1 小时前
算法日常记录
java·算法·leetcode
27669582921 小时前
美团民宿 mtgsig 小程序 mtgsig1.2 分析
java·python·小程序·美团·mtgsig·mtgsig1.2·美团民宿
爱的叹息1 小时前
Java 连接 Redis 的驱动(Jedis、Lettuce、Redisson、Spring Data Redis)分类及对比
java·redis·spring
程序猿chen1 小时前
《JVM考古现场(十五):熵火燎原——从量子递归到热寂晶壁的代码涅槃》
java·jvm·git·后端·java-ee·区块链·量子计算
松韬2 小时前
Spring + Redisson:从 0 到 1 搭建高可用分布式缓存系统
java·redis·分布式·spring·缓存
绝顶少年2 小时前
Spring Boot 注解:深度解析与应用场景
java·spring boot·后端