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

C++怎么实现一个读写锁_C++并发编程与读写锁实现

裘德小鎮的故事
发布: 2025-11-17 16:05:51
原创
397人浏览过
答案是使用std::shared_mutex实现读写锁,允许多个读线程共享访问、写线程独占访问,提升读多写少场景的并发性能;C++17中通过lock_shared()和lock()分别获取读锁和写锁,配合std::shared_lock和std::unique_lock实现RAII管理,避免资源泄漏;若兼容C++11,则可用mutex与condition_variable手动实现读写状态控制,确保读时不写、写时互斥。

c++怎么实现一个读写锁_c++并发编程与读写锁实现

在C++中实现读写锁(Reader-Writer Lock),核心目标是允许多个读线程同时访问共享资源,但写线程独占访问。这种机制适用于“读多写少”的场景,能显著提升并发性能。

使用标准库的 shared_mutex 实现读写锁

C++17 起提供了 std::shared_mutex,天然支持读写锁语义:

  • 共享所有权(读锁):多个线程可同时获得共享锁(.lock_shared())
  • 独占所有权(写锁):仅一个线程可获得独占锁(.lock())
示例代码:

<pre class="brush:php;toolbar:false;">#include <shared_mutex><br>#include <thread><br>#include <vector><br>#include <iostream><br><br>std::shared_mutex rw_mutex;<br>int data = 0;<br><br>void reader(int id) {<br>    rw_mutex.lock_shared();<br>    std::cout << "Reader " << id << " reads data: " << data << "\n";<br>    rw_mutex.unlock_shared();<br>}<br><br>void writer(int id) {<br>    rw_mutex.lock();<br>    data += id;<br>    std::cout << "Writer " << id << " writes data: " << data << "\n";<br>    rw_mutex.unlock();<br>}<br><br>int main() {<br>    std::vector<std::thread> threads;<br>    for (int i = 0; i < 3; ++i) {<br>        threads.emplace_back(reader, i);<br>    }<br>    threads.emplace_back(writer, 10);<br>    threads.emplace_back(reader, 99);<br><br>    for (auto& t : threads) t.join();<br>    return 0;<br>}
登录后复制

输出中,多个读线程可能同时执行,而写线程会阻塞所有读操作。

手动实现简易读写锁(C++11 兼容)

若不能使用 C++17,可用互斥量和条件变量模拟读写锁逻辑。

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

基本思路:

火龙果写作
火龙果写作

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

火龙果写作 106
查看详情 火龙果写作
  • std::mutex 保护读写状态
  • std::condition_variable 协调读写线程
  • 维护当前活跃读线程数和是否正在写
简化实现:

<pre class="brush:php;toolbar:false;">class ReadWriteLock {<br>private:<br>    std::mutex mtx;<br>    std::condition_variable cv;<br>    int readers{0};<br>    bool writing{false};<br><br>public:<br>    void lock_read() {<br>        std::unique_lock<std::mutex> lock(mtx);<br>        cv.wait(lock, [this] { return !writing; });<br>        readers++;<br>    }<br><br>    void unlock_read() {<br>        std::lock_guard<std::mutex> lock(mtx);<br>        readers--;<br>        if (readers == 0) cv.notify_all();<br>    }<br><br>    void lock_write() {<br>        std::unique_lock<std::mutex> lock(mtx);<br>        cv.wait(lock, [this] { return !writing && readers == 0; });<br>        writing = true;<br>    }<br><br>    void unlock_write() {<br>        std::lock_guard<std::mutex> lock(mtx);<br>        writing = false;<br>        cv.notify_all();<br>    }<br>};
登录后复制

使用时需注意避免死锁,比如不要在持有读锁时尝试获取写锁。

RAII 封装提升安全性

为避免忘记解锁,应使用 RAII 包装器:

  • std::shared_lock<std::shared_mutex>:管理共享锁(读)
  • std::unique_lock<std::shared_mutex>:管理独占锁(写)
示例:

<pre class="brush:php;toolbar:false;">std::shared_mutex rw_mutex;<br><br>void safe_read() {<br>    std::shared_lock lock(rw_mutex);<br>    // 自动加共享锁,作用域结束自动释放<br>    std::cout << "Reading: " << data << "\n";<br>}<br><br>void safe_write(int val) {<br>    std::unique_lock lock(rw_mutex);<br>    data = val;<br>}
登录后复制

RAII 是 C++ 并发编程的最佳实践,极大降低资源管理错误风险。

基本上就这些。优先使用 std::shared_mutex + std::shared_lock/unique_lock,简洁高效。若需兼容旧标准,可手写基于 condition_variable 的版本,但务必测试竞争边界情况。

以上就是C++怎么实现一个读写锁_C++并发编程与读写锁实现的详细内容,更多请关注php中文网其它相关文章!

编程速学教程(入门课程)
编程速学教程(入门课程)

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

下载
来源: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号