0

0

在Java中如何调优并发程序的吞吐量_Java并发性能优化与提升解析

P粉602998670

P粉602998670

发布时间:2026-02-11 12:42:09

|

198人浏览过

|

来源于php中文网

原创

线程数设为CPU核心数×2导致卡顿,是因忽略I/O等待、锁竞争和上下文切换开销;混合任务应从核心数+1开始压测,避免阻塞操作拖垮ForkJoinPool。

在java中如何调优并发程序的吞吐量_java并发性能优化与提升解析

为什么线程数设为 CPU 核心数 × 2 就卡顿?

这不是经验公式的失效,而是忽略了 I/O 等待、锁竞争和上下文切换的实际开销。当 ThreadPoolExecutor 的核心线程数盲目设为 Runtime.getRuntime().availableProcessors() * 2,而任务实际含数据库查询或远程调用时,大量线程会阻塞在 WAITINGBLOCKED 状态,反而加剧调度负担。

实操建议:

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

  • jstack 抓取线程快照,统计 java.lang.Thread.State: WAITING 占比;若超 60%,说明线程过载,应降配并引入异步 I/O(如 CompletableFuture + HttpClient 非阻塞模式)
  • 对纯计算型任务,线程数可设为 availableProcessors();对混合型任务,从 availableProcessors() + 1 开始压测,观察 GC 日志中 GC pause 与吞吐量拐点
  • 避免复用同一 ForkJoinPool 执行阻塞操作,否则会拖垮整个公共池——改用自定义 ThreadPoolExecutor 并设置 allowCoreThreadTimeOut(true)

ConcurrentHashMap.computeIfAbsent 为什么在高并发下变慢?

Java 8 的 computeIfAbsent 在 key 对应的桶为空时会加锁,但若传入的 mappingFunction 耗时较长(比如查 DB 或解析 JSON),会导致该桶长期被独占,其他线程在该桶上形成排队等待,吞吐量骤降。

实操建议:

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

  • 绝不在 computeIfAbsent 的 lambda 中做任何 I/O 或重计算;只做轻量对象构造(如 new HashMap()
  • 若需懒加载复杂对象,先用 putIfAbsent 尝试插入占位符(如 FutureTask),再由单一线程异步初始化,其他线程 await 获取结果
  • JDK 17+ 可考虑 ConcurrentHashMap.newKeySet() 配合外部缓存策略,规避 compute 类方法的锁粒度问题

CountDownLatch.await() 超时后为何线程没释放?

常见错误是只调用 countDown() 一次,却在多线程中反复 await —— CountDownLatch 是一次性门闩,一旦计数归零,后续所有 await() 立即返回,但若业务逻辑未检查返回值就继续执行,可能造成空指针或状态不一致,间接拖慢整体流程。

Interior AI
Interior AI

AI室内设计,上传室内照片自动帮你生成多种风格的室内设计图

下载

实操建议:

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

  • 永远用 if (latch.await(3, TimeUnit.SECONDS)) { /* 正常路径 */ } else { /* 超时处理:清理资源、抛异常或降级 */ }
  • 不要用 CountDownLatch 控制循环节奏;改用 Semaphore 限流或 Phaser 多阶段同步
  • 在单元测试中模拟超时场景,验证 finally 块是否能正确释放 Lock、关闭 Socket 等资源——漏掉这个,压测时连接池耗尽比吞吐下降更致命

用 JMH 测吞吐量时,为什么结果总飘忽不定?

JMH 默认的预热轮次(@Fork + @Warmup)不足以让 JIT 编译器稳定优化分支预测和内联深度,尤其当被测方法含 if-else 链或 switch 表时,不同轮次可能走不同编译路径,导致 ops/ms 波动超过 ±25%。

实操建议:

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

  • 至少配置 @Fork(jvmArgs = {"-XX:+UnlockDiagnosticVMOptions", "-XX:+PrintAssembly"}) 查看热点方法是否被 C2 编译,再决定是否增加 @Warmup(iterations = 10)
  • 禁用分层编译(-XX:-TieredStopAtLevel)强制使用 C2,消除解释执行干扰
  • @State(Scope.Benchmark) 管理共享对象,但切忌在 @Setup 中初始化 ConcurrentHashMap 并直接注入——应延迟到第一次 @Benchmark 调用时按需构建,否则预热数据污染真实测量

真正卡住吞吐量的,往往不是算法复杂度,而是某次 System.out.println() 被留在生产日志里,或是某个 static final Map 初始化时偷偷触发了类加载锁。调优要盯住线程栈和 GC 日志里的“异常平稳”——那通常意味着瓶颈藏在你看不见的地方。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
json数据格式
json数据格式

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

436

2023.08.07

json是什么
json是什么

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

543

2023.08.23

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

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

317

2023.10.13

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

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

81

2025.09.10

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

803

2023.08.22

switch语句用法
switch语句用法

switch语句用法:1、Switch语句只能用于整数类型,枚举类型和String类型,不能用于浮点数类型和布尔类型;2、每个case语句后面必须跟着一个break语句,以防止执行其他case的代码块,没有break语句,将会继续执行下一个case的代码块;3、可以在一个case语句中匹配多个值,使用逗号分隔;4、Switch语句中的default代码块是可选的等等。

550

2023.09.21

Java switch的用法
Java switch的用法

Java中的switch语句用于根据不同的条件执行不同的代码块。想了解更多switch的相关内容,可以阅读本专题下面的文章。

430

2024.03.13

lambda表达式
lambda表达式

Lambda表达式是一种匿名函数的简洁表示方式,它可以在需要函数作为参数的地方使用,并提供了一种更简洁、更灵活的编码方式,其语法为“lambda 参数列表: 表达式”,参数列表是函数的参数,可以包含一个或多个参数,用逗号分隔,表达式是函数的执行体,用于定义函数的具体操作。本专题为大家提供lambda表达式相关的文章、下载、课程内容,供大家免费下载体验。

211

2023.09.15

Rust异步编程与Tokio运行时实战
Rust异步编程与Tokio运行时实战

本专题聚焦 Rust 语言的异步编程模型,深入讲解 async/await 机制与 Tokio 运行时的核心原理。内容包括异步任务调度、Future 执行模型、并发安全、网络 IO 编程以及高并发场景下的性能优化。通过实战示例,帮助开发者使用 Rust 构建高性能、低延迟的后端服务与网络应用。

1

2026.02.11

热门下载

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

精品课程

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

共23课时 | 3.4万人学习

C# 教程
C# 教程

共94课时 | 9.1万人学习

Java 教程
Java 教程

共578课时 | 62.6万人学习

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

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