0

0

什么是ReadWriteLock读写锁_提高读多写少场景并发性能的方案

P粉602998670

P粉602998670

发布时间:2026-02-13 11:57:13

|

526人浏览过

|

来源于php中文网

原创

readwritelock适用于读多写少场景,核心判断是读频远高于写频且读不修改状态;需避免读锁中调写操作、加锁不配对、读锁升级等错误,非公平模式更常用。

什么是readwritelock读写锁_提高读多写少场景并发性能的方案

ReadWriteLock 是 Java 并发包里专为「读多写少」场景设计的锁协议,它不直接提供锁,而是一套规范——真正干活的是它的实现类,比如 ReentrantReadWriteLock。用对了,读操作能并发执行,吞吐翻倍;用错了,反而比 synchronized 还慢,还容易死锁或数据不一致。

什么时候该用 ReentrantReadWriteLock 而不是 ReentrantLock

核心判断就一条:你的共享数据是否「被读的频率远高于被写的频率」,且读操作本身不修改状态。

  • 适合:缓存加载后只读、配置中心快照、只增不删的索引映射表(如 Map<string config></string>
  • 不适合:高频更新的计数器、需要读-改-写原子性的场景(如 value++)、写操作占比超过 20% 的业务逻辑
  • 特别注意:如果读操作里偷偷调用了可能触发写的方法(比如 getter 里调了 computeIfAbsent),那读锁就形同虚设,必须统一用写锁

readLock()writeLock() 必须配对使用,且不能交叉加锁

这是最常踩的坑:读锁没释放就去抢写锁,或者写锁没释放就试图再拿读锁——都会导致线程永久阻塞。

腾讯混元文生视频
腾讯混元文生视频

腾讯发布的AI视频生成大模型技术

下载
  • readLock().lock() 后必须对应 readLock().unlock(),哪怕只是 try-with-resources 也得确认 AutoCloseable 实现正确(ReentrantReadWriteLock.ReadLock 不是自动关闭的)
  • 写线程可以「降级」:先持 writeLock,再拿 readLock,然后释放写锁,保留读锁(用于后续只读校验)
  • 读线程绝对不能「升级」:持有 readLock 时调 writeLock().lock() 会一直阻塞,JVM 不支持这种升级
  • 示例错误写法:
    readLock.lock();
    try {
        if (needUpdate()) {
            writeLock.lock(); // ⚠️ 死锁起点
            ...
        }
    } finally {
        readLock.unlock();
    }

公平模式 vs 非公平模式:别默认用公平,除非你真在压测中看到写饥饿

ReentrantReadWriteLock 默认是非公平的,这意味着新来的读线程可能插队,把排队等写锁的线程饿很久——但实测中,非公平模式吞吐高 15%~30%,尤其在读压力大的服务里。

  • 开启公平只需传 truenew ReentrantReadWriteLock(true)
  • 公平模式下,写锁永远优先于新读请求;但如果已有大量读锁被持有,写线程仍需等所有读锁释放完才能上
  • 真实业务中,95% 场景用非公平就够了;只有监控发现 writeLock 等待时间持续 > 50ms,才考虑切公平

为什么 StampedLock 不是 ReadWriteLock 的替代品

很多人听说 StampedLock 性能更好,就直接替换,结果出问题——它不保证锁的可重入性,也不兼容中断,更关键的是:乐观读失败后若没做 validate 检查,会读到脏数据。

  • StampedLocktryOptimisticRead() 返回的是一个 stamp,不是锁,它不阻塞也不注册线程,纯靠事后校验
  • 一旦发生写操作,所有未 validate 的乐观读都失效,你得兜底切悲观读,代码复杂度陡增
  • 如果你的读操作涉及多个字段、或需要强一致性(比如读取用户余额+冻结金额两个字段),老老实实用 ReentrantReadWriteLock.readLock() 更安全
读写锁不是银弹,它把「锁粒度」从「整块数据」细化到「读/写语义」,但代价是开发者必须对访问模式有清晰认知。最容易被忽略的,其实是读操作里隐藏的写副作用——上线前务必用 JMH 做混合读写压测,而不是只测纯读。
数码产品性能查询
数码产品性能查询

该软件包括了市面上所有手机CPU,手机跑分情况,电脑CPU,电脑产品信息等等,方便需要大家查阅数码产品最新情况,了解产品特性,能够进行对比选择最具性价比的商品。

下载

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
线程和进程的区别
线程和进程的区别

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

673

2023.08.10

golang map内存释放
golang map内存释放

本专题整合了golang map内存相关教程,阅读专题下面的文章了解更多相关内容。

75

2025.09.05

golang map相关教程
golang map相关教程

本专题整合了golang map相关教程,阅读专题下面的文章了解更多详细内容。

36

2025.11.16

golang map原理
golang map原理

本专题整合了golang map相关内容,阅读专题下面的文章了解更多详细内容。

65

2025.11.17

java判断map相关教程
java判断map相关教程

本专题整合了java判断map相关教程,阅读专题下面的文章了解更多详细内容。

44

2025.11.27

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

23

2026.02.13

微博网页版主页入口与登录指南_官方网页端快速访问方法
微博网页版主页入口与登录指南_官方网页端快速访问方法

本专题系统整理微博网页版官方入口及网页端登录方式,涵盖首页直达地址、账号登录流程与常见访问问题说明,帮助用户快速找到微博官网主页,实现便捷、安全的网页端登录与内容浏览体验。

11

2026.02.13

Flutter跨平台开发与状态管理实战
Flutter跨平台开发与状态管理实战

本专题围绕Flutter框架展开,系统讲解跨平台UI构建原理与状态管理方案。内容涵盖Widget生命周期、路由管理、Provider与Bloc状态管理模式、网络请求封装及性能优化技巧。通过实战项目演示,帮助开发者构建流畅、可维护的跨平台移动应用。

7

2026.02.13

TypeScript工程化开发与Vite构建优化实践
TypeScript工程化开发与Vite构建优化实践

本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。

8

2026.02.13

热门下载

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

精品课程

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

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