0

0

C++的std::shared_lock如何实现多读单写的读写锁模式? (并发效率提升)

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-02-11 14:30:11

|

323人浏览过

|

来源于php中文网

原创

std::shared_lock只是SharedMutex的RAII封装,不实现读写锁逻辑;真正提供多读单写语义的是std::shared_mutex等底层互斥体,二者配合才能实现读并发、写独占。

c++的std::shared_lock如何实现多读单写的读写锁模式? (并发效率提升)

std::shared_lock 本身不实现读写锁,它只是共享所有权的 RAII 封装

很多人以为 std::shared_lock 是“读锁”,甚至能和 std::unique_lock 配合自动实现多读单写——其实不是。std::shared_lock 只负责在构造时调用底层 shared_lockable 对象(如 std::shared_mutex)的 lock_shared(),析构时调用 unlock_shared()。它自己不调度、不阻塞、不判断读写冲突。

真正承担读写语义的是它所包装的互斥体类型。C++17 起,std::shared_mutex 才是标准中首个满足 SharedMutex 概念的类型;C++20 还补充了更轻量的 std::shared_timed_mutex(但实际使用中几乎被弃用)。

  • std::shared_lock 必须搭配 std::shared_mutex(或自定义满足 SharedMutex 的类型),单独用它毫无意义
  • 不能拿 std::mutex 初始化 std::shared_lock,编译直接报错:no matching constructor
  • std::shared_lock 支持移动,但不支持拷贝——这是为了防止意外延长共享持有时间

怎么配对使用 std::shared_mutex + std::shared_lock 实现多读单写

核心逻辑就一条:读操作用 std::shared_lock<:shared_mutex>,写操作用 std::unique_lock<:shared_mutex>。两者底层都操作同一个 std::shared_mutex 实例,由该互斥体内部保证“多个 shared_lock 可同时持有,但会阻塞 unique_lock;而 unique_lock 持有时,所有 new shared_lock 都要等待”。

典型用法:

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

Flowith
Flowith

一款GPT4驱动的节点式 AI 创作工具

下载
std::shared_mutex rw_mutex;
std::vector data;

// 读路径 void read_data() { std::shared_lock lock(rw_mutex); // → 调用 lock_shared() for (int x : data) { / ... / } }

// 写路径 void write_data(int x) { std::unique_lock lock(rw_mutex); // → 调用 lock() data.push_back(x); }

  • 读操作必须用 std::shared_lock(不能用 std::unique_lock),否则失去并发读能力
  • 写操作可以用 std::unique_lock 或直接 rw_mutex.lock(),但推荐前者——便于异常安全和延迟锁定
  • 不要混用 std::shared_timed_mutexstd::shared_lock:它虽兼容,但性能差、API 冗余,C++20 已标记为 deprecated

为什么有时候读操作还是被写操作卡住?常见阻塞原因

即使代码写对了,实测仍可能发现读延迟高、吞吐上不去——问题往往不在 std::shared_lock,而在锁粒度或竞争模式。

  • 写操作太频繁或太长:哪怕只有一小段临界区,只要写锁没释放,所有新进的 std::shared_lock 都得排队等,旧读锁不受影响,但新读请求会被阻塞
  • 误在循环内反复构造/析构 std::shared_lock:比如在遍历容器时每轮都加锁解锁,开销远大于一次锁住整个遍历
  • 锁对象生命周期超出必要范围:例如把 std::shared_mutex 声明为全局变量,导致模块间无意共享,放大争用
  • 调试器或日志打点在临界区内:看似无关,但若日志函数内部有锁或系统调用,可能间接拖慢锁持有时间

Windows / GCC / Clang 下的兼容性与性能提醒

std::shared_mutex 在不同平台实现差异明显,直接影响你能否真拿到“多读并发”收益。

  • Linux(GCC/Clang + glibc):底层通常映射到 futexpthread_rwlock_t,读写分离做得比较干净,多读性能好
  • Windows(MSVC):早期版本(VS2015/2017)用临界区模拟,读写都串行化;VS2019 起才用 SRWLock,真正支持无锁读并发
  • macOS:libc++ 直到 Xcode 14(2022)才完成 std::shared_mutex 的完整实现,旧版本可能静默退化为普通互斥体
  • 别依赖 try_lock_shared() 的“零开销”:它在某些实现里仍是系统调用,高频率轮询反而比阻塞式更伤性能

真实项目里,如果读写比极高且对延迟敏感,先确认目标平台的 std::shared_mutex 是否真正启用硬件级读写分离——不然花力气改锁策略,效果可能不如换个更激进的无锁结构或分片设计。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
全局变量怎么定义
全局变量怎么定义

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

85

2025.09.18

python 全局变量
python 全局变量

本专题整合了python中全局变量定义相关教程,阅读专题下面的文章了解更多详细内容。

101

2025.09.18

windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

1024

2023.07.26

查看端口占用情况windows
查看端口占用情况windows

端口占用是指与端口关联的软件占用端口而使得其他应用程序无法使用这些端口,端口占用问题是计算机系统编程领域的一个常见问题,端口占用的根本原因可能是操作系统的一些错误,服务器也可能会出现端口占用问题。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1145

2023.07.27

windows照片无法显示
windows照片无法显示

当我们尝试打开一张图片时,可能会出现一个错误提示,提示说"Windows照片查看器无法显示此图片,因为计算机上的可用内存不足",本专题为大家提供windows照片无法显示相关的文章,帮助大家解决该问题。

817

2023.08.01

windows查看端口被占用的情况
windows查看端口被占用的情况

windows查看端口被占用的情况的方法:1、使用Windows自带的资源监视器;2、使用命令提示符查看端口信息;3、使用任务管理器查看占用端口的进程。本专题为大家提供windows查看端口被占用的情况的相关的文章、下载、课程内容,供大家免费下载体验。

457

2023.08.02

windows无法访问共享电脑
windows无法访问共享电脑

在现代社会中,共享电脑是办公室和家庭的重要组成部分。然而,有时我们可能会遇到Windows无法访问共享电脑的问题。这个问题可能会导致数据无法共享,影响工作和生活的正常进行。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

2356

2023.08.08

windows自动更新
windows自动更新

Windows操作系统的自动更新功能可以确保系统及时获取最新的补丁和安全更新,以提高系统的稳定性和安全性。然而,有时候我们可能希望暂时或永久地关闭Windows的自动更新功能。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

850

2023.08.10

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

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

1

2026.02.11

热门下载

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

精品课程

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

共94课时 | 9.1万人学习

C 教程
C 教程

共75课时 | 4.6万人学习

C++教程
C++教程

共115课时 | 17.1万人学习

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

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