首页 > 后端开发 > C++ > 正文

c++怎么实现一个读写锁_c++读写锁read-write lock实现方法

裘德小鎮的故事
发布: 2025-10-18 21:26:01
原创
487人浏览过
答案:C++中读写锁允许多个读线程共享访问、写线程独占访问,C++14起推荐使用std::shared_mutex实现,支持lock_shared()和lock()操作,读写互斥且写时禁止读;示例代码展示了5个读线程和2个写线程对共享数据的并发访问控制。

c++怎么实现一个读写锁_c++读写锁read-write lock实现方法

在C++中实现读写锁(Read-Write Lock),核心目标是允许多个读线程同时访问共享资源,但写线程独占访问。也就是说:读共享、写独占、写时禁止读。

使用标准库实现读写锁(C++14及以上)

C++14起,std::shared_mutex 提供了对读写锁的原生支持,是最推荐的方式。

示例代码:

#include <iostream><br>#include <thread><br>#include <vector><br>#include <shared_mutex><br>#include <chrono>
<p>std::shared_mutex rw_mutex;
int shared_data = 0;</p><p>void reader(int id) {
rw_mutex.lock_shared(); // 获取读锁
std::cout << "Reader " << id << " reads data: " << shared_data << "\n";
std::this_thread::sleep_for(std::chrono::milliseconds(100)); // 模拟读操作
rw_mutex.unlock_shared(); // 释放读锁
}</p><p>void writer(int id) {
rw_mutex.lock(); // 获取写锁(独占)
std::cout << "Writer " << id << " writes data.\n";
shared_data++;
std::this_thread::sleep_for(std::chrono::milliseconds(200));
rw_mutex.unlock(); // 释放写锁
}</p><p>int main() {
std::vector<std::thread> threads;
for (int i = 0; i < 5; ++i) {
threads.emplace_back(reader, i);
}
for (int i = 0; i < 2; ++i) {
threads.emplace_back(writer, i);
}
for (auto& t : threads) {
t.join();
}
return 0;
}
登录后复制

说明:
- lock_shared():多个线程可同时获取读锁。
- lock():写锁是独占的,任一时刻只能一个线程持有。
- C++17还提供 std::shared_timed_mutex,支持带超时的锁操作。

手动实现简易读写锁(基于互斥量)

若环境不支持 std::shared_mutex,可以用 std::mutex 和条件变量模拟。

基本思路:
  • 用一个互斥量保护读写状态
  • 维护当前活跃读线程数
  • 写线程需等待所有读线程退出后才能进入

代码实现:

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

火龙果写作
火龙果写作

用火龙果,轻松写作,通过校对、改写、扩展等功能实现高质量内容生产。

火龙果写作 106
查看详情 火龙果写作
#include <mutex><br>#include <condition_variable>
<p>class ReadWriteLock {
private:
std::mutex mtx;
std::condition_variable cv;
int read_count = 0;
bool writing = false;</p><p>public:
void lock_read() {
std::unique_lock<std::mutex> lock(mtx);
cv.wait(lock, [this] { return !writing; });
++read_count;
lock.unlock();
}</p><pre class="brush:php;toolbar:false;"><pre class="brush:php;toolbar:false;">void unlock_read() {
    std::lock_guard<std::mutex> lock(mtx);
    --read_count;
    if (read_count == 0) {
        cv.notify_all();
    }
}

void lock_write() {
    std::unique_lock<std::mutex> lock(mtx);
    cv.wait(lock, [this] { return !writing && read_count == 0; });
    writing = true;
}

void unlock_write() {
    std::lock_guard<std::mutex> lock(mtx);
    writing = false;
    cv.notify_all();
}
登录后复制

};

使用方式与标准库类似,但注意这种实现可能有性能开销和公平性问题(比如写线程可能饿死)。

使用场景与注意事项

读写锁适合读多写少的场景,如缓存、配置管理等。

  • 避免在持有读锁时尝试获取写锁,容易死锁
  • 频繁写入时,读写锁可能不如普通互斥锁高效
  • 某些系统提供 pthread_rwlock_t(POSIX),也可封装使用

基本上就这些。优先使用 std::shared_mutex,简洁安全。需要兼容旧标准时再考虑手动实现。

以上就是c++++怎么实现一个读写锁_c++读写锁read-write lock实现方法的详细内容,更多请关注php中文网其它相关文章!

c++速学教程(入门到精通)
c++速学教程(入门到精通)

c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

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