当前位置: 首页
编程语言
怎么区分 Stream 流的并行处理 parallel() 与普通处理在底层线程池(ForkJoinPool)的共用

怎么区分 Stream 流的并行处理 parallel() 与普通处理在底层线程池(ForkJoinPool)的共用

热心网友 时间:2026-04-29
转载

怎么区分 Stream 流的并行处理 parallel() 与普通处理在底层线程池(ForkJoinPool)的共用

怎么区分 Stream 流的并行处理 parallel() 与普通处理在底层线程池(ForkJoinPool)的共用

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

简单来说,并行流的 parallel() 并不创建新线程池,而是直接复用 JVM 全局共享的 ForkJoinPool.commonPool()。普通流(stream())则完全是另一回事——它只在当前调用线程中顺序执行,根本不涉及任何线程池和并发调度。

parallel() 的线程池来源是固定的

所有未显式指定线程池的并行流,底层都走同一个 ForkJoinPool 实例:ForkJoinPool.commonPool()。这里有个关键点:这个池子不是每次调用时新建的,而是 JVM 启动时初始化一次的静态共享池。

  • 它的默认并行度计算公式是:Runtime.getRuntime().a vailableProcessors() - 1。举个例子,在一台8核的机器上,默认就是7个并行线程。
  • 这个默认值是可以提前配置的,通过系统属性就能调整:System.setProperty("ja va.util.concurrent.ForkJoinPool.common.parallelism", "12");
  • 需要注意的是,这个设置是全局性的。它影响的不仅仅是 parallelStream,所有使用 commonPool 的地方都会生效,比如 ForkJoinTask.invoke()CompletableFuture 的默认异步执行。

普通流 stream() 完全不依赖线程池

list.stream().filter(...).map(...) 这样的普通流操作,整个链路都在当前线程内完成。没有任务提交、没有工作窃取、也没有线程调度的开销。它的执行模型和传统的 for 循环一样,是纯同步、单线程且行为可预测的。

  • 它不会触发任何 ForkJoinPool 的初始化。
  • 不会占用 commonPool 的线程或队列资源。
  • 即使在多线程环境中调用,每个线程也只是各自执行自己的 stream 操作,彼此完全隔离。

如何验证是否共用同一个 commonPool

想亲眼看看是不是真的共用一个池子?可以通过打印线程名或检查池状态来验证:

  • 在 parallelStream 操作中打印线程名:
    .forEach(x -> System.out.println(Thread.currentThread().getName()))
    你会看到输出中包含类似 ForkJoinPool.commonPool-worker-1 这样的名称。
  • 对比调用 ForkJoinPool.commonPool().toString()list.parallelStream().count() 前后,池子的 activeThreadCount 或 poolSize 等状态值会发生变化。
  • 最直接的证据是,当多个并行流同时运行时,它们的子任务会竞争同一组 worker 线程,而不是各自独占一套资源。

注意:sequential() 不会切换线程池

这里有个容易混淆的地方:调用 .parallel().sequential() 只是让后续操作退回到单线程顺序执行模式。但是,整个流可能已经在 commonPool 中启动过 fork/join 分支了。这个方法并不会释放线程,也不会切换到其他池子——它的作用仅仅是“不再进行并行调度”,而实际执行任务的线程,很可能还是 commonPool 里的某个 worker。

来源:https://www.php.cn/faq/2387677.html

游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

同类文章
更多
Debian如何检查Java安装是否成功

Debian如何检查Java安装是否成功

在Debian系统中检查Ja va安装是否成功 在Debian系统上折腾Ja va环境,安装完成只是第一步。怎么确认它真的装好了,能正常跑起来?这事儿其实很简单,跟着下面几个步骤走一遍,心里就有底了。 第一步:打开终端 所有操作都离不开终端(Terminal)。你可以通过系统菜单找到它,或者直接用快

时间:2026-04-29 19:01
Debian Java编译出现内存不足怎么办

Debian Java编译出现内存不足怎么办

Debian Ja va编译内存不足的实用处理方案 遇到Ja va编译时内存不足,确实让人头疼。别急,这事儿有清晰的解决路径。关键在于先定位问题,再对症下药。下面这套从诊断到根治的方案,能帮你系统性地搞定它。 一 快速定位与通用思路 动手调整之前,先得弄清楚状况。盲目加内存可能治标不治本。 确认是编

时间:2026-04-29 19:00
Debian Java版本如何选择合适

Debian Java版本如何选择合适

Debian 选择 Ja va 版本的可操作指南 在 Debian 系统上配置 Ja va 环境,第一步往往不是急着安装,而是先想清楚:你到底需要什么?是追求极致的稳定,还是尝鲜最新的特性?不同的选择,决定了后续完全不同的技术路径。 一 选择依据 面对众多版本,如何做出明智的选择?其实,只要抓住下面

时间:2026-04-29 19:00
Debian PHP如何跨平台兼容

Debian PHP如何跨平台兼容

Debian PHP跨平台兼容实践指南 一 基础环境标准化 跨平台兼容的基石,在于构建一个统一且可靠的基础环境。这第一步走稳了,后续的麻烦能少一大半。 统一 PHP 版本与扩展:在 Debian 上,首要任务是安装与项目严格匹配的 PHP 版本(例如 PHP 8 1 或 8 2)。建议通过包管理器一

时间:2026-04-29 19:00
Debian系统如何更新Golang编译版本

Debian系统如何更新Golang编译版本

Debian 系统如何升级 Go 语言版本:四种高效方法详解 一 首选方案:官方二进制包直接安装 核心建议:若您希望获取最新的 Go 稳定版本,或需要灵活管理多个 Go 版本,直接从 Go 语言官网下载预编译的二进制包是最直接、最可控的升级方案。 移除旧版本(可选,防止干扰):若系统已通过包管理器安

时间:2026-04-29 19:00
热门专题
更多
刀塔传奇破解版无限钻石下载大全 刀塔传奇破解版无限钻石下载大全
洛克王国正式正版手游下载安装大全 洛克王国正式正版手游下载安装大全
思美人手游下载专区 思美人手游下载专区
好玩的阿拉德之怒游戏下载合集 好玩的阿拉德之怒游戏下载合集
不思议迷宫手游下载合集 不思议迷宫手游下载合集
百宝袋汉化组游戏最新合集 百宝袋汉化组游戏最新合集
jsk游戏合集30款游戏大全 jsk游戏合集30款游戏大全
宾果消消消原版下载大全 宾果消消消原版下载大全
  • 日榜
  • 周榜
  • 月榜
热门教程
更多
  • 游戏攻略
  • 安卓教程
  • 苹果教程
  • 电脑教程