0

0

Java中的ReadWriteLock怎么用_读写锁分离提升高并发读场景性能实战

P粉602998670

P粉602998670

发布时间:2026-03-10 11:48:32

|

487人浏览过

|

来源于php中文网

原创

readwritelock 是接口,不能直接 new,必须使用其实现类 reentrantreadwritelock;读写锁需正确配对加解锁,禁止锁升级,适用读多写少场景。

java中的readwritelock怎么用_读写锁分离提升高并发读场景性能实战

ReadWriteLock 为什么不能直接 new?

Java 里 ReadWriteLock 是接口,不是具体实现——你写 new ReadWriteLock() 会编译报错。真正能用的是它的标准实现类 ReentrantReadWriteLock,它支持重入、可选公平性,也是 JDK 自带且最常被选中的方案。

常见错误现象:NoClassDefFoundError 或直接编译失败,往往是因为只 import 了接口却没实例化对的类。

  • 必须用 new ReentrantReadWriteLock()(默认非公平)或 new ReentrantReadWriteLock(true)(公平模式)
  • 公平模式会降低吞吐量,但能避免写线程饥饿;高并发读场景下,通常用默认非公平就够了
  • 别在每次方法调用里 new 一个新锁——它是有状态的,应作为成员变量复用

readLock() 和 writeLock() 怎么配对加解锁?

读锁和写锁是两个独立的 Lock 对象,各自管理自己的 lock() / unlock(),但共享同一套锁状态。用错配对会导致死锁或数据不一致。

典型误用:用 readLock().lock() 加锁,却调用 writeLock().unlock() —— 这不会释放任何锁,还可能掩盖问题。

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

Beautiful.ai
Beautiful.ai

AI在线创建幻灯片

下载
  • 读操作必须配对:先 readLock().lock(),再 readLock().unlock()
  • 写操作同理:writeLock().lock()writeLock().unlock()
  • 推荐用 try-finally(或 try-with-resources 封装),否则异常时 unlock 漏掉,锁就永远卡住
  • 示例:
    readLock.lock();
    try {
        return data.get(key);
    } finally {
        readLock.unlock();
    }

什么时候读锁反而比 synchronized 还慢?

读写锁不是银弹。当读操作极短(比如只读一个 volatile 字段)、或读写比例严重失衡(如 99% 写 + 1% 读),ReentrantReadWriteLock 的额外状态维护开销(CAS 更新 state、队列管理、线程唤醒)反而拖慢性能。

容易踩的坑:盲目替换所有 synchronized 为读写锁,结果压测 QPS 下降。

  • 适合场景:读多写少(比如 >80% 读)、读操作耗时明显(如查 Map、拼接字符串、简单计算)
  • 不适合场景:临界区只有 1–2 行代码;或写操作频繁且不可预测(如高频计数器)
  • 注意:ReentrantReadWriteLock 的读锁不排斥其他读锁,但会阻塞写锁;写锁则排斥一切(读+写)——这点和数据库的读写锁语义一致
  • 可通过 JMH 做微基准测试,对比 synchronized vs readLock 在真实业务逻辑下的平均延迟

升级写锁时为什么不能直接 lock(writeLock)?

从读锁“升级”到写锁(即先持读锁,再想拿写锁)是非法操作,ReentrantReadWriteLock 明确禁止——会死锁。因为写锁要等所有读锁释放,而你正拿着读锁不放。

常见错误现象:线程卡在 writeLock.lock(),jstack 显示 BLOCKED,且持有该线程的 readLock 状态未释放。

  • 正确做法只有两种:
    ① 先释放读锁,再获取写锁(但中间存在竞态窗口)
    ② 直接用写锁保护整个读-改-写流程(如果业务允许)
  • 若必须“读后再决定是否写”,建议用乐观策略:先读,判断需更新后,释放读锁 → 获取写锁 → 再读一次(防中途被改)→ 更新
  • 不要试图用 tryLock() 绕过——失败后仍得处理重试或降级逻辑,复杂度陡增
读写锁的关键不在“用了没”,而在“读写边界划得准不准”——读操作里混了写逻辑、锁粒度跨了方法边界、或者把锁当成万能同步替代品,都比不用还危险。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
js 字符串转数组
js 字符串转数组

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

739

2023.08.03

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

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

220

2023.09.04

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

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

1564

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

649

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

1208

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

1184

2024.04.29

go语言字符串相关教程
go语言字符串相关教程

本专题整合了go语言字符串相关教程,阅读专题下面的文章了解更多详细内容。

191

2025.07.29

c++字符串相关教程
c++字符串相关教程

本专题整合了c++字符串相关教程,阅读专题下面的文章了解更多详细内容。

111

2025.08.07

Kotlin Android模块化架构与组件化开发实践
Kotlin Android模块化架构与组件化开发实践

本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。

24

2026.03.09

热门下载

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

精品课程

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

共23课时 | 4.2万人学习

C# 教程
C# 教程

共94课时 | 11万人学习

Java 教程
Java 教程

共578课时 | 79.3万人学习

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

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