0

0

在Java中ReentrantLock相比synchronized的优势_Java锁对比解析

P粉602998670

P粉602998670

发布时间:2026-02-04 11:49:02

|

849人浏览过

|

来源于php中文网

原创

ReentrantLock 支持中断等待、多 Condition、可尝试获取锁及公平性可选,synchronized 则无中断响应、单等待队列、无非阻塞获取且默认非公平;使用 ReentrantLock 须严格配对 lock/unlock 并善用高级特性。

在java中reentrantlock相比synchronized的优势_java锁对比解析

ReentrantLock 支持中断等待,synchronized 会卡死线程

当一个线程在等锁时被外部中断(比如用户取消任务、超时熔断),synchronized 完全无感——它会继续傻等,直到拿到锁或 JVM 终止。而 ReentrantLock 提供 lockInterruptibly(),让线程能及时响应 InterruptedException 并退出等待。

  • 典型场景:RPC 调用超时、批处理任务主动终止、Web 请求 cancel 按钮
  • 错误写法:lock.lock() 仍会忽略中断;必须用 lock.lockInterruptibly()
  • 注意:调用该方法的代码必须声明 throws InterruptedException,且不能在 catch 里吞掉异常

ReentrantLock 可绑定多个 Condition,synchronized 只有 wait/notify 一套机制

synchronized 下所有 wait() 都挤在同一个队列里,notifyAll() 一喊全醒,再靠 while 循环过滤条件,效率低还容易误唤醒。ReentrantLock 允许通过 lock.newCondition() 创建多个独立的等待队列,比如「生产者等 notFull」和「消费者等 notEmpty」互不干扰。

  • 真实需求:阻塞队列、读写分离、状态机驱动的协作(如“等初始化完成”“等配置加载完毕”)
  • 关键点:Condition.await() 会自动释放锁,signal() 不会立即抢锁,而是让对应等待线程参与下一轮竞争
  • 别漏掉 signal()signalAll(),否则线程永远沉睡

ReentrantLock 能尝试获取锁,synchronized 没有“非阻塞”选项

synchronized 是“要么拿到,要么挂起”,没有中间态。而 ReentrantLocktryLock()tryLock(long, TimeUnit) 让你可以控制是否等待、等多久、甚至放弃后干别的事。

  • 适用场景:避免死锁(按顺序 tryLock)、短时临界区快速失败、后台健康检查轮询
  • 常见坑:tryLock() 返回 false 时没做任何处理,导致逻辑跳过关键校验
  • 注意:即使 tryLock() 成功,也必须配对 unlock(),否则锁泄漏

公平性可选,但默认非公平——别误以为 ReentrantLock 天然更“公平”

ReentrantLock 构造时传 true 才是公平锁(new ReentrantLock(true)),否则和 synchronized 一样是非公平的。公平锁看似合理,但实测吞吐量常下降 20%~50%,因为要维护 FIFO 队列+额外 CAS 开销。

秘塔写作猫
秘塔写作猫

秘塔写作猫是一个集AI写作、校对、润色、配图等为一体的创作平台

下载

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

  • 只在明确存在“线程饥饿”风险时启用公平模式,比如长耗时任务 + 大量短任务混跑
  • synchronized 根本不提供公平开关,JVM 实现就是非公平的,这点两者一致
  • 别为了“心理公平”滥用公平锁,高并发下它反而拖慢整体响应

真正难的不是选哪个锁,而是判断要不要锁——很多性能问题其实源于过度同步,或者把锁粒度搞得太粗。用 ReentrantLock 的高级功能前,先确认你是不是真需要它;而一旦用了,lock()/unlock() 必须成对出现在 try/finally 里,这是唯一不能妥协的底线。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
while的用法
while的用法

while的用法是“while 条件: 代码块”,条件是一个表达式,当条件为真时,执行代码块,然后再次判断条件是否为真,如果为真则继续执行代码块,直到条件为假为止。本专题为大家提供while相关的文章、下载、课程内容,供大家免费下载体验。

98

2023.09.25

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

589

2023.08.10

java连接字符串方法汇总
java连接字符串方法汇总

本专题整合了java连接字符串教程合集,阅读专题下面的文章了解更多详细操作。

4

2026.02.05

java中fail含义
java中fail含义

本专题整合了java中fail的含义、作用相关内容,阅读专题下面的文章了解更多详细内容。

8

2026.02.05

控制反转和依赖注入区别
控制反转和依赖注入区别

本专题整合了控制反转和依赖注入区别、解释、实现方法相关内容。阅读专题下面的文章了解更多详细教程。

9

2026.02.05

钉钉脑图插图教程合集
钉钉脑图插图教程合集

本专题整合了钉钉脑图怎么插入图片、钉钉脑图怎么用相关教程,阅读专题下面的文章了解更多详细内容。

17

2026.02.05

python截取字符串方法汇总
python截取字符串方法汇总

本专题整合了python截取字符串方法相关合集,阅读专题下面的文章了解更多详细内容。

2

2026.02.05

Java截取字符串方法合集
Java截取字符串方法合集

本专题整合了Java截取字符串方法汇总,阅读专题下面的文章了解更多详细操作教程。

1

2026.02.05

java 抽象方法
java 抽象方法

本专题整合了java抽象方法定义、作用教程等内容,阅读专题下面的文章了解更多详细内容。

2

2026.02.05

热门下载

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

精品课程

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

共23课时 | 3.2万人学习

C# 教程
C# 教程

共94课时 | 8.6万人学习

Java 教程
Java 教程

共578课时 | 57.8万人学习

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

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