0

0

c++中std::shared_mutex(读写锁)的使用_c++多线程读写锁同步实例

尼克

尼克

发布时间:2025-11-18 16:42:05

|

792人浏览过

|

来源于php中文网

原创

c++kquote>std::shared_mutex支持读写锁机制,允许多个读线程同时访问共享资源,提升读多写少场景下的并发性能。

c++中std::shared_mutex(读写锁)的使用_c++多线程读写锁同步实例

在C++多线程编程中,当多个线程需要访问共享资源时,如果读操作远多于写操作,使用普通的互斥锁(std::mutex)会降低并发性能。因为互斥锁无论读写都独占资源,而实际上多个读操作可以同时进行。这时候就需要用到 std::shared_mutex —— 它支持共享所有权,实现读写锁机制:允许多个线程同时读(共享模式),但写操作必须独占(独占模式)。

std::shared_mutex 简介

std::shared_mutex 是 C++17 引入的标准库组件,定义在头文件 中。它支持两种加锁方式:

  • 共享锁(shared lock):通过 lock_shared()try_lock_shared() 获取,用于读操作,可被多个线程同时持有。
  • 独占锁(exclusive lock):通过 lock()try_lock() 获取,用于写操作,只能由一个线程持有,且不能与共享锁共存。

对应的,我们通常使用 std::shared_lock 来管理共享锁,用 std::unique_lock 管理独占锁。

多线程读写同步实例

下面是一个典型示例:多个线程对一个共享的整数容器进行读写操作,使用 std::shared_mutex 保证线程安全。

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

奇布塔
奇布塔

基于AI生成技术的一站式有声绘本创作平台

下载
#include 
#include 
#include 
#include 
#include 
#include 

std::vector data = {1, 2, 3, 4, 5}; std::shared_mutex smtx; // 共享互斥量

// 读操作:计算总和 void reader(int id) { std::shared_lock lock(smtx); // 获取共享锁 std::this_thread::sleep_for(std::chrono::milliseconds(100)); // 模拟处理时间 int sum = std::accumulate(data.begin(), data.end(), 0); std::cout << "Reader " << id << " sees sum: " << sum << "\n"; }

// 写操作:向容器添加一个元素 void writer(int id) { std::unique_lock lock(smtx); // 获取独占锁 std::this_thread::sleep_for(std::chrono::milliseconds(200)); int new_val = id * 10; data.push_back(new_val); std::cout << "Writer " << id << " added: " << new_val << "\n"; }

int main() { std::vector threads;

// 启动3个写线程和5个读线程
for (int i = 0; i zuojiankuohaophpcn 3; ++i) {
    threads.emplace_back(writer, i + 1);
}
for (int i = 0; i zuojiankuohaophpcn 5; ++i) {
    threads.emplace_back(reader, i + 1);
}

// 等待所有线程完成
for (auto& t : threads) {
    t.join();
}

return 0;

}

运行结果与分析

输出可能类似:

Reader 1 sees sum: 15
Writer 1 added: 10
Reader 2 sees sum: 25
Reader 3 sees sum: 25
Writer 2 added: 20
Reader 4 sees sum: 35
Reader 5 sees sum: 35
Writer 3 added: 30

可以看到:

  • 多个读线程可以同时执行,它们看到的是加锁时刻的数据状态。
  • 写线程必须等待所有正在进行的读操作完成才能获取锁;同样,读线程也必须等待写操作结束才能开始。
  • 每次写入后,后续读取能看到更新后的数据。

使用建议与注意事项

使用 std::shared_mutex 时注意以下几点:

  • 确保编译器支持 C++17 及以上标准(如 g++ -std=c++17)。
  • 频繁的写操作会使共享锁“饥饿”,即读线程一直无法获得锁,需根据场景评估是否适合。
  • 避免在持有共享锁期间尝试升级为独占锁(C++ 标准不支持自动升级,容易死锁)。
  • 长时间持有共享锁会影响写线程响应速度,应尽量缩短锁的持有时间。

基本上就这些。std::shared_mutex 在读多写少的场景下能显著提升并发效率,是多线程编程中非常实用的同步工具。合理使用 shared_lock 和 unique_lock 配合 shared_mutex,可以让代码更清晰、安全。

相关专题

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

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

482

2023.08.10

Python 多线程与异步编程实战
Python 多线程与异步编程实战

本专题系统讲解 Python 多线程与异步编程的核心概念与实战技巧,包括 threading 模块基础、线程同步机制、GIL 原理、asyncio 异步任务管理、协程与事件循环、任务调度与异常处理。通过实战示例,帮助学习者掌握 如何构建高性能、多任务并发的 Python 应用。

143

2025.12.24

java多线程相关教程合集
java多线程相关教程合集

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

5

2026.01.21

C++多线程相关合集
C++多线程相关合集

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

11

2026.01.21

Golang 性能分析与pprof调优实战
Golang 性能分析与pprof调优实战

本专题系统讲解 Golang 应用的性能分析与调优方法,重点覆盖 pprof 的使用方式,包括 CPU、内存、阻塞与 goroutine 分析,火焰图解读,常见性能瓶颈定位思路,以及在真实项目中进行针对性优化的实践技巧。通过案例讲解,帮助开发者掌握 用数据驱动的方式持续提升 Go 程序性能与稳定性。

9

2026.01.22

html编辑相关教程合集
html编辑相关教程合集

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

56

2026.01.21

三角洲入口地址合集
三角洲入口地址合集

本专题整合了三角洲入口地址合集,阅读专题下面的文章了解更多详细内容。

30

2026.01.21

AO3中文版入口地址大全
AO3中文版入口地址大全

本专题整合了AO3中文版入口地址大全,阅读专题下面的的文章了解更多详细内容。

393

2026.01.21

妖精漫画入口地址合集
妖精漫画入口地址合集

本专题整合了妖精漫画入口地址合集,阅读专题下面的文章了解更多详细内容。

116

2026.01.21

热门下载

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

精品课程

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

共58课时 | 4万人学习

Pandas 教程
Pandas 教程

共15课时 | 0.9万人学习

ASP 教程
ASP 教程

共34课时 | 3.9万人学习

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

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