• 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() 则主要用于对集合进行遍历,并且保持了元素的顺序性,适用于简单的遍历操作。
    fori
    for (int i = 0; i < objects.size(); i++) {}
    foreach
    for (Object o : objects) {}
    fori最普通的循环,可以时候得到当前的索引位置。
     
    foreach 和fori区别不大,foreach是普通fori的增强版用起来更方便。但是没有当前索引。
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    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 -> {
            });
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
  • 相关阅读:
    JDK源码分析实战系列-PriorityQueue
    vue3+emelenui实现前端分页功能—最简单
    RestTemplate 集成拦截器
    Spring MVC 启动流程?
    conda命令
    【lesson8】操作系统的理解和类比
    Vue3对话框样式修改不了
    基于springboot人事管理系统java项目介绍
    【RocketMQ】【源码】DLedger选主源码分析
    java源码系列:HashMap底层存储原理详解——6、演示1.7底层实现原理验证-如何使用哈希算法、数组存储
  • 原文地址:https://blog.csdn.net/Fireworkit/article/details/134472334