0

0

在Java里并发编程常见误区有哪些_Java多线程问题解析

P粉602998670

P粉602998670

发布时间:2026-02-01 12:49:49

|

602人浏览过

|

来源于php中文网

原创

volatile不能保证原子性,++操作含读-改-写三步,多线程下仍会丢失更新;synchronized锁的是对象而非方法,不同实例无互斥;ThreadLocal不自动清理value易致内存泄漏;Executors.newFixedThreadPool()用无界队列,高负载易OOM。

在java里并发编程常见误区有哪些_java多线程问题解析

volatile 不能保证原子性,别把它当锁用

很多人看到 volatile 能禁止指令重排、保证可见性,就以为给 count 加了 volatile 就能安全自增。实际不是:++ 操作本身是读-改-写三步,volatile 不拦着其他线程插在中间执行。结果就是两个线程同时读到 1,各自加成 2,最后写回还是 2,丢了一次更新。

常见错误现象:volatile int count = 0; 配合多线程 count++,最终值远小于预期。

  • 正确做法:用 AtomicIntegerincrementAndGet(),或用 synchronized 块保护临界区
  • 注意:volatile 适合“一写多读”且操作本身是原子的场景,比如状态标志位 isRunning
  • 性能上,volatile 比锁轻量,但比普通变量重;别为了省事硬套在非原子操作上

synchronized 锁的是对象,不是代码块或方法名

写个 synchronized void methodA(),就以为所有调用它的线程都会互斥?错。锁的是当前实例(this),如果多个线程操作的是不同对象,那根本没锁住。静态方法锁的是类对象(MyClass.class),和实例锁完全不相干。

常见错误现象:启动多个 new Task() 实例,每个都调用 synchronized 方法更新共享资源,结果还是并发冲突。

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

MagicLight AI
MagicLight AI

AI动画视频创作平台

下载
  • 确认锁目标:想保护全局资源,优先用类锁(synchronized(MyClass.class))或显式静态锁对象
  • 避免锁字符串字面量(如 synchronized("key")),容易因字符串常量池被意外共享
  • 锁粒度要小心:锁整个方法可能过度,改成只锁关键段能提升吞吐

ThreadLocal 不是万能的“线程私有存储”,用完不清理会内存泄漏

ThreadLocal 确实让每个线程拿到自己的副本,但底层是靠线程内部的 ThreadLocalMap 存值,而这个 map 的 key 是 ThreadLocal 的弱引用——value 却是强引用。一旦 ThreadLocal 实例被回收(比如定义为局部变量),key 变 null,但 value 还挂着,GC 清不掉,尤其在线程池里反复复用线程时,越积越多。

常见错误现象:Web 应用跑几天后 OOM,堆里堆满 ThreadLocalMap$Entry,value 是大对象(比如用户上下文、数据库连接)。

  • 务必在业务结束时调用 threadLocal.remove(),别依赖 set(null)
  • 不要把 ThreadLocal 当成“自动清理”的容器;它只是延迟绑定,不自动释放
  • 线程池场景下,建议在任务执行前后统一做 remove(),或用 try-finally 包裹

Executors.newFixedThreadPool() 在高负载下可能直接 OOM

这个工厂方法背后用的是无界队列 LinkedBlockingQueue,意味着只要任务提交速度 > 执行速度,队列就无限增长。一旦突发流量打进来,大量任务排队,堆内存很快撑爆。

常见错误现象:系统在压测或高峰时突然 OutOfMemoryError: Java heap spacejstack 显示大量线程阻塞在 take(),堆 dump 里全是待执行的 Runnable

  • 生产环境禁用 Executors.newFixedThreadPool()newCachedThreadPool()
  • 改用 ThreadPoolExecutor 构造器,明确指定有界队列(如 ArrayBlockingQueue)和拒绝策略(如 AbortPolicy 或自定义降级逻辑)
  • 队列大小不能拍脑袋定:结合平均任务耗时、QPS、可接受排队时长来估算,宁小勿大
真正难的不是记住这些规则,而是上线前能不能想到“我的线程池会不会吃光内存”“这个 volatile 变量是不是真被所有线程看到”——往往出问题的,都是那些看起来“应该没问题”的地方。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

237

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

499

2024.03.01

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1503

2023.10.24

counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

198

2023.11.20

字符串常量的表示方法
字符串常量的表示方法

字符串常量的表示方法:1、使用引号;2、转义字符;3、多行字符串;4、原始字符串;5、字符串连接;6、字符串字面量和对象;7、编码问题。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

140

2023.12.26

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

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

361

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

212

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1503

2023.10.24

go语言 注释编码
go语言 注释编码

本专题整合了go语言注释、注释规范等等内容,阅读专题下面的文章了解更多详细内容。

30

2026.01.31

热门下载

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

精品课程

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

共23课时 | 3.1万人学习

C# 教程
C# 教程

共94课时 | 8.2万人学习

Java 教程
Java 教程

共578课时 | 55.4万人学习

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

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