【JDK 8-集合框架进阶】6.1 parallelStream 并行流

[一、parallelStream 并行流](#一、parallelStream 并行流)

[1.1 串行 和 并行的区别](#1.1 串行 和 并行的区别)

[> 执行结果](#> 执行结果)

二、问题

[2.1 paralleStream 并行是否一定比 Stream 串行快?](#2.1 paralleStream 并行是否一定比 Stream 串行快?)

[2.2 是否可以都用并行?](#2.2 是否可以都用并行?)

[> 报错](#> 报错)

三、实战

[> 执行结果](#> 执行结果)

四、总结


一、parallelStream 并行流

  • 多线程并发处理,速度快

  • fork/join 框架提供了并发执行能力

  • 底层原理: 线程池(ForkjoinPool) 维护一个线程队列,将父任务拆分成子任务

1.1 串行 和 并行的区别

java 复制代码
    public static void main(String[] args) {
        List<Integer> list = Arrays.asList(1,2,3,4,5,6,7,8,9);
        System.out.println(">> 【串行 stream()】单线程");
        list.stream().forEach(System.out::println);
        System.out.println(">> 【并行 parallelStream()】多线程");
        list.parallelStream().forEach(System.out::println);

    }

> 执行结果

二、问题

2.1 paralleStream 并行是否一定比 Stream 串行快?

  • 错误,数据量少的情况,可能串行更快,ForkJoin会耗性能。

  • 多数情况下并行比串行快

2.2 是否可以都用并行?

  • 不行,部分情况会有线程安全问题,parallelStream里面使用的外部变量,比如集合一定要使用线程安全集合,不然就会引发多线程安全问题
java 复制代码
        for (int i = 0; i < 10; i++) {
            List list1 = new ArrayList();
            IntStream.range(0,100).parallel().forEach(list1::add);
            System.out.println(list1.size());
        }

> 报错

三、实战

java 复制代码
        for (int i = 0; i < 10; i++) {
            List list1 = new CopyOnWriteArrayList();
            IntStream.range(0,100).parallel().forEach(list1::add);
            System.out.println(list1.size());
        }

> 执行结果

四、总结

一般 list.size()

  • 几十个:使用 Stream

  • 几百个以上:paralleStream

相关推荐
袁雅倩19974 小时前
当吸尘器、筋膜枪都用上Type-C,供电方案该怎么选?浅谈PD取电芯片ECP5702的应用
c语言·开发语言·支持向量机·动态规划·推荐算法·最小二乘法·图搜索算法
2301_809204704 小时前
JavaScript中严格模式use-strict对引擎解析的辅助.txt
jvm·数据库·python
zjy277774 小时前
mysql如何选择合适的索引类型_mysql索引设计实战
jvm·数据库·python
Aaswk4 小时前
Java Lambda 表达式与流处理
java·开发语言·python
是宇写的啊5 小时前
Spring AOP
java·spring
万邦科技Lafite5 小时前
京东item_get接口实战案例:实时商品价格监控全流程解析
java·开发语言·数据库·python·开放api·淘宝开放平台
Cyber4K6 小时前
【Python专项】进阶语法-系统资源监控与数据采集(1)
开发语言·python·php
Mr_pyx6 小时前
Spring AI 入门教程:Java开发者的AI应用捷径
java·人工智能·spring
Le_ee6 小时前
ctfweb:php/php短标签/.haccess+图片马/XXE
开发语言·前端·php
冷小鱼6 小时前
JVM 异常崩溃排查全指南:从 Core Dump 到根因定位
jvm