4核跑Stream的多线程还比不上Stream的单线程

上代码:

    public static void main(String[] args) {
        System.out.println(String.format("本计算机的核数:%d", Runtime.getRuntime().availableProcessors()));
        // 产⽣100w个随机数(1 ~ 100),组成列表
        Random random = new Random();
        List<Integer> list = new ArrayList<>(1000_0000);
        for (int i = 0; i < 1000_0000; i++) {
            list.add(random.nextInt(100));
        }
        long prevTime = getCurrentTime();
        list.stream().reduce((a, b) -> a + b).ifPresent(System.out::println);
        System.out.println(String.format("单线程计算耗时:%d", getCurrentTime() - prevTime ));
        prevTime = getCurrentTime();
        list.stream().parallel().reduce((a, b) -> a + b).ifPresent(System.out::println);
        System.out.println(String.format("多线程计算耗时:%d", getCurrentTime() -prevTime));
    }

结果:

本计算机的核数:4
495028607
单线程计算耗时:227
495028607
多线程计算耗时:979

4核跑Stream的多线程还比不上Stream的单线程!

猜你喜欢

转载自blog.csdn.net/liuruiaaa/article/details/130913218
今日推荐