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

在C++中实现读写锁(Reader-Writer Lock),核心目标是允许多个读线程同时访问共享资源,但写线程独占访问。这种机制适用于“读多写少”的场景,能显著提升并发性能。
C++17 起提供了 std::shared_mutex,天然支持读写锁语义:
<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++17,可用互斥量和条件变量模拟读写锁逻辑。
立即学习“C++免费学习笔记(深入)”;
基本思路:
<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 包装器:
<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中文网其它相关文章!
编程怎么学习?编程怎么入门?编程在哪学?编程怎么学才快?不用担心,这里为大家提供了编程速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号