std::shared_mutex通过共享锁允许多线程并发读,独占锁保证写时独占,适用于读多写少场景。使用std::shared_lock加读锁,std::unique_lock加写锁,需c++17支持,注意读操作不可修改数据以避免竞争。

在C++中,std::shared_mutex 是实现读写锁的关键工具,它允许多个线程同时进行读操作,但在写操作时独占访问资源。这种机制特别适合“读多写少”的场景,能显著提升并发性能。
理解 shared_mutex 的两种加锁方式
std::shared_mutex 支持两种锁定模式:
- 共享锁(shared lock):多个线程可同时获得,适用于读操作。
- 独占锁(exclusive lock):仅一个线程能获得,适用于写操作。
使用 std::shared_lock 获取共享锁,用 std::unique_lock 获取独占锁。
基本用法示例
下面是一个典型的读写操作示例:
立即学习“C++免费学习笔记(深入)”;
#include <shared_mutex>
#include <thread>
#include <vector>
#include <iostream>
std::vector<int> data;
std::shared_mutex mtx;
// 读线程函数
void reader(int id) {
std::shared_lock<std::shared_mutex> lock(mtx);
std::cout << "Reader " << id << " sees data size: " << data.size() << "\n";
}
// 写线程函数
void writer(int id) {
std::unique_lock<std::shared_mutex> lock(mtx);
data.push_back(id);
std::cout << "Writer " << id << " added item\n";
}
int main() {
std::vector<std::thread> threads;
// 启动多个读线程和少量写线程
for (int i = 0; i < 10; ++i) {
threads.emplace_back(reader, i);
}
for (int i = 0; i < 2; ++i) {
threads.emplace_back(writer, i + 100);
}
for (auto& t : threads) {
t.join();
}
}
提升高并发读性能的实践建议
为了充分发挥 std::shared_mutex 在高并发读场景下的优势,注意以下几点:
- 确保读操作不修改数据,否则应使用写锁。
- 尽量减少写操作频率,避免长时间持有独占锁。
- 在频繁读、极少写的场景中,shared_mutex 比互斥锁(mutex)性能更高。
- 注意编译器支持:需 C++17 及以上,并链接对应标准库(如 -std=c++17)。
基本上就这些。只要合理区分读写路径,shared_mutex 能有效提升多线程程序的吞吐量。不复杂但容易忽略的是:别让读操作意外修改了共享状态。











