java中for和forEach的速度比较实例Demo

背景

之前和同事讨论一个问题,他们公司调研中发现forEach的速度比for的速度慢,当刚听到这个结论的时候有点诧异。因为之前看过国外的文章和他们公司的结论一样,但是测试用例单一。今天正好在看flink相关的流处理,正好想起来了这个问题,然后简单的写了一个demo来进行推翻这个结论。

废话不多说直接上代码吧

package pers.bik.flink;

import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.atomic.AtomicInteger;
import java.util.stream.IntStream;

/**
 * @author yangkaifei
 * @date 2021/8/10 11:28 下午
 * @cersion 1.0
 */
public class Test {

    public static void main(String[] args) {
        List<Integer> list = new ArrayList<>();
        IntStream.range(0, 1000).forEach(number -> list.add(number));
        streamForEach(list);
        parallelStreamForEach(list);
        forI(list);
        strengthFor(list);
    }

    /**
     * 串行流forEach
     * @param list
     */
    private static void streamForEach(List<Integer> list) {
        AtomicInteger i = new AtomicInteger();
        long startTime = System.currentTimeMillis();
        list.stream().forEach(number -> {
            String s = String.valueOf(number);
            i.getAndIncrement();
        });
        long endTime = System.currentTimeMillis();
        System.out.println(String.format("streamForEach:%s", endTime - startTime));
    }

    /**
     * 并行流forEach
     * @param list
     */
    private static void parallelStreamForEach(List<Integer> list) {
        AtomicInteger i = new AtomicInteger();
        long startTime = System.currentTimeMillis();
        list.parallelStream().forEach(number -> {
            String s = String.valueOf(number);
            i.getAndIncrement();
        });
        long endTime = System.currentTimeMillis();
        System.out.println(String.format("parallelStreamForEach:%s", endTime - startTime));
    }

    /**
     * for i
     * @param list
     */
    private static void forI(List<Integer> list) {
        AtomicInteger i = new AtomicInteger();
        long startTime = System.currentTimeMillis();
        for (int j = 0; j < list.size(); j++) {
            String s = String.valueOf(list.get(j));
            i.getAndIncrement();
        }

        long endTime = System.currentTimeMillis();
        System.out.println(String.format("forI:%s", endTime - startTime));
    }

    /**
     * 增强for循环
     * @param list
     */
    private static void strengthFor(List<Integer> list) {
        AtomicInteger i = new AtomicInteger();
        long startTime = System.currentTimeMillis();
        for (Integer integer : list) {
            String s = String.valueOf(integer);
            i.getAndIncrement();
        }
        long endTime = System.currentTimeMillis();
        System.out.println(String.format("strengthFor:%s", endTime - startTime));
    }
}

运行结果:

streamForEach:2041
parallelStreamForEach:352
forI:468
strengthFor:411

结论:

对于for、增强for循环、forEach不能单纯的抛开业务场景就去肯定的给出一个结论。forEach的速度未必就比for循环慢。

当我再次调整,将数量调整为1000的时候,运行的结果又会发生变化

IntStream.range(0, 1000).forEach(number -> list.add(number));

运行结果

streamForEach:1
parallelStreamForEach:4
forI:0
strengthFor:1

对比两个不同的数据量,运行的结果也不尽相同(当然代码有些不严谨,但是完全可以推翻forEach一定比for慢的结论,或者说A一定比B快的结论)。

在软件开发中,对于一切别人给定的结论我们要抱着质疑的态度,只有当自己亲身去调研的时候才能说服自己。

总结

到此这篇关于java中for和forEach速度的文章就介绍到这了,更多相关java中for和forEach速度内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Java中遍历数组使用foreach循环还是for循环?

    从JDK1.5起,增加了新功能Foreach,它是for循环遍历数据的一种简写形式,使用的关键字依然是for,但参数格式不同.其详细用法为: for(Type e:collection){ //对变量e的使用} 参数说明: e:其类型Type是集合或数组中元素值的类型,该参数是集合或数组collection中的一个元素. collections: 要遍历的集合或数组,也可以是迭代器. 在循环体中使用参数e,该参数是foreach从集合或数组以及迭代器中取得的元素值,元素值是从头到尾进行遍历的.

  • java程序中foreach用法示例

    语法 复制代码 代码如下: for (Object objectname : preArrayList(一个Object对象的列表)) {} 示例 复制代码 代码如下: package com.kuaff.jdk5;import java.util.*; import java.util.Collection; public class Foreach{private Collection c = null; private String[] belle = new String[4]; pub

  • java8 forEach结合Lambda表达式遍历 List操作

    我就废话不多说了,大家还是直接看代码吧~ @Test void testJava8ForeachMap() { Map<String, Integer> items = new HashMap<>(); items.put("A", 10); items.put("B", 20); items.put("C", 30); items.put("D", 40); items.put("E&quo

  • Java中ArrayList在foreach里remove的问题详析

    前言 ArrayList就是传说中的动态数组,用MSDN中的说法,就是Array的复杂版本,它提供了如下一些好处: 动态的增加和减少元素 实现了ICollection和IList接口 灵活的设置数组的大小 都说ArrayList在用foreach循环的时候,不能add元素,也不能remove元素,可能会抛异常,那我们就来分析一下它具体的实现.我目前的环境是Java8. 有下面一段代码: public class TestForEachList extends BaseTests { @Test

  • 详解Java中的增强 for 循环 foreach

    foreach 是 Java 中的一种语法糖,几乎每一种语言都有一些这样的语法糖来方便程序员进行开发,编译期间以特定的字节码或特定的方式来对这些语法进行处理.能够提高性能,并减少代码出错的几率.在 Java 中还有比如 泛型.自动拆箱.自动装箱.内部类.枚举等等. foreach 是用来对数组或者集合进行遍历的语法.具体语法如下: for(元素类型 ele : 数组名/Iterable 实例){ } 下面我们用 foreach 来对数组和一个集合进行遍历: int [] array = {1,2

  • 深入理解java中for和foreach循环

    •for循环中的循环条件中的变量只求一次值!具体看最后的图片 •foreach语句是java5新增,在遍历数组.集合的时候,foreach拥有不错的性能. •foreach是for语句的简化,但是foreach并不能替代for循环.可以这么说,任何foreach都能改写为for循环,但是反之则行不通. •foreach不是java中的关键字.foreach的循环对象一般是一个集合,List.ArrayList.LinkedList.Vector.数组等. •foreach的格式: for(元素类

  • 详解Java8的forEach(...)如何提供index值

    Java2遍历集合 遍历Collection的代码,可以是采用Iterator接口,通过next()遍历.如: List<String> list = Arrays.asList("Hi", "I", "am", "Henry.Yao"); // 此处已经用到了泛型,不能算是纯粹的Java2代码,仅作Iterator示范 for (Iterator<String> it = list.iterator(

  • 浅析java的foreach循环

    使用foreach循环遍历数组和集合时,无需获得数组和集合的长度,无须根据索引来访问数组元素和集合元素,foreach循环自动遍历数组和集合的每一个元素. 复制代码 代码如下: foreach的语句格式: for(type variableName : array|connection){      //variable自动迭代访问每一个元素} 例子: 复制代码 代码如下: public class ForEachTest{public static void main(String[] arg

  • java 使用foreach遍历集合元素的实例

    java 使用foreach遍历集合元素的实例 1 代码示例 import java.util.*; public class ForeachTest { public static void main(String[] args) { // 创建集合.添加元素的代码与前一个程序相同 Collection books = new HashSet(); books.add(new String("book1")); books.add(new String("book2&quo

  • 深入了解java8的foreach循环

    虽然java8出来很久了,但是之前用的一直也不多,最近正好学习了java8,推荐一本书还是不错的<写给大忙人看的javase8>.因为学习了Java8,所以只要能用到的地方都会去用,尤其是Java8的Stream,感觉用起来觉得很方便,因为点点点就出来了,而且代码那么简洁.现在开始慢慢深入了解java8,发现很多东西不能看表面. 比如常规遍历一个集合,下面给出例子: 1.首先遍历一个List 方式1.一开始是这样的: public static void test1(List<Strin

随机推荐