0

0

在Java里如何使用parallelStream并行处理集合_Java集合并行操作说明

P粉602998670

P粉602998670

发布时间:2026-01-15 14:53:02

|

851人浏览过

|

来源于php中文网

原创

parallelstream仅在数据量大、单个元素处理耗时明显(如i/o或复杂计算)时才比stream快;小集合(如size

在java里如何使用parallelstream并行处理集合_java集合并行操作说明

parallelStream 什么时候比 stream

并行流不是银弹,只有在数据量大、单个元素处理耗时明显(比如含 I/O 或复杂计算)时才可能提速。小集合(如 list.size() )用 <code>parallelStream() 反而更慢——线程创建、任务拆分、结果合并的开销压过了并行收益。

常见误判场景:list.parallelStream().map(String::toUpperCase).collect(Collectors.toList()) 这类纯内存轻量操作,几乎总比串行慢。

  • 适合:遍历万级对象,每个做 HTTP 请求、JSON 解析、正则匹配
  • 不适合:遍历百级列表,只做 Integer::intValue 或字符串拼接
  • 验证方法:用 System.nanoTime() 对比,别靠感觉

共享变量导致结果错乱的典型写法

parallelStream 默认使用 ForkJoinPool.commonPool(),所有任务共享线程,若在 lambda 中修改外部变量(尤其非线程安全容器),结果必然不可控。

List<String> result = new ArrayList<>(); // 错!ArrayList 不是线程安全的
list.parallelStream()
    .forEach(s -> result.add(s.toUpperCase())); // 多线程并发 add → 数据丢失或异常

正确做法是用线程安全的收集方式:

立即学习Java免费学习笔记(深入)”;

Rezi.ai
Rezi.ai

一个使用 AI 自动化创建简历平台

下载
  • collect()list.parallelStream().map(String::toUpperCase).collect(Collectors.toList())
  • 用线程安全容器 + forEachOrdered()(但失去并行意义)
  • 避免副作用:lambda 内不读写外部可变状态

自定义线程池控制 parallelStream 并发度

commonPool 默认线程数 = Runtime.getRuntime().availableProcessors() - 1,对 CPU 密集型任务尚可,但遇到 I/O 操作多的任务,需要更多线程才能压满资源。

不能直接替换 parallelStream() 的执行器,得绕一下:

ForkJoinPool pool = new ForkJoinPool(8);
List<String> result = pool.submit(() ->
    list.parallelStream()
        .map(this::heavyCompute)
        .collect(Collectors.toList())
).join();
  • 必须调用 submit().join(),否则任务不执行
  • 记得 pool.shutdown()(尤其在短生命周期应用中)
  • Spring 环境可用 @Async + 自定义 TaskExecutor 替代,更可控

parallelStream 在 ArrayList 和 LinkedList 上性能差异大

parallelStream 底层依赖 Splitter 拆分数据源。只有支持随机访问(RandomAccess)的集合(如 ArrayList、数组)才能高效切分;LinkedList 拆分时需遍历定位,性能断崖式下跌,甚至不如串行。

实测:10 万元素的 LinkedList.parallelStream() 可能比 ArrayList.stream() 慢 5 倍以上。

  • 始终优先用 ArrayList 或数组做并行源
  • 若只有 LinkedList,先 new ArrayList(original) 再并行
  • HashSet/TreeSet 无序且不保证拆分效率,也不推荐直接并行

parallelStream 前先问自己:数据够多吗?操作够重吗?集合类型合适吗?外部状态干净吗?四个问题里有一个答不上,就老实用 stream()

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
spring框架介绍
spring框架介绍

本专题整合了spring框架相关内容,想了解更多详细内容,请阅读专题下面的文章。

155

2025.08.06

Java Spring Security 与认证授权
Java Spring Security 与认证授权

本专题系统讲解 Java Spring Security 框架在认证与授权中的应用,涵盖用户身份验证、权限控制、JWT与OAuth2实现、跨站请求伪造(CSRF)防护、会话管理与安全漏洞防范。通过实际项目案例,帮助学习者掌握如何 使用 Spring Security 实现高安全性认证与授权机制,提升 Web 应用的安全性与用户数据保护。

88

2026.01.26

json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

454

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

546

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

334

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

82

2025.09.10

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

990

2023.08.02

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

739

2023.08.03

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

4

2026.03.10

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 4.3万人学习

C# 教程
C# 教程

共94课时 | 11万人学习

Java 教程
Java 教程

共578课时 | 80万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号