c++17中新增了shared_mutex,它允许多个读线程同时访问共享数据,但在写线程访问时,所有的读线程和其他写线程都会被阻塞。
示例:
#include <shared_mutex>
std::shared_mutex mutex;
// 读线程
void reader() {
std::shared_lock<std::shared_mutex> lock(mutex);
// 访问共享数据
}
// 写线程
void writer() {
std::unique_lock<std::shared_mutex> lock(mutex);
// 访问共享数据
}
读线程使用std::shared_lock进行上锁,写线程使用std::unique_lock进行上锁。
当有写线程上锁时,其他所有读线程和写线程都会阻塞。当没有写线程上锁时,多个读线程可以同时上锁并访问共享数据。
std::shared_mutex适用于读操作远大于写操作,并且读操作不依赖于写操作的场景。它可以大大提高性能,因为它允许并发读取。
另外,与std::mutex相比,std::shared_mutex有以下区别:
- std::shared_mutex支持多个读线程同时上锁,std::mutex不支持。
- std::shared_mutex写线程上锁后阻塞所有其他读写线程,std::mutex只阻塞其他写线程。
- std::shared_mutex不支持递归上锁,std::mutex支持。