值得一看
广告
彩虹云商城
广告

热门广告位

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

答案: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++免费学习笔记(深入)”;

#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();
}

};

火龙果写作

火龙果写作

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

火龙果写作106

查看详情
火龙果写作

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

使用场景与注意事项

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

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

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

相关标签:

ai c++ ios stream 并发访问 标准库 red 封装 线程 并发

大家都在看:

虚拟伴侣AI如何实现24小时在线 虚拟伴侣AI持续运行机制的维护指南
老照片修复AI使用教程 老照片修复AI平台地址
灵绘AI如何处理高清图像_灵绘AI高清图像生成与优化方法
虚拟伴侣AI如何设置互动游戏 虚拟伴侣AI娱乐功能的开发技巧
AI推文助手如何生成情感化文案 AI推文助手的情感营销创作指南
温馨提示: 本文最后更新于2025-10-18 22:30:30,某些文章具有时效性,若有错误或已失效,请在下方留言或联系在线客服
文章版权声明 1 本网站名称: 创客网
2 本站永久网址:https://new.ie310.com
1 本文采用非商业性使用-相同方式共享 4.0 国际许可协议[CC BY-NC-SA]进行授权
2 本站所有内容仅供参考,分享出来是为了可以给大家提供新的思路。
3 互联网转载资源会有一些其他联系方式,请大家不要盲目相信,被骗本站概不负责!
4 本网站只做项目揭秘,无法一对一教学指导,每篇文章内都含项目全套的教程讲解,请仔细阅读。
5 本站分享的所有平台仅供展示,本站不对平台真实性负责,站长建议大家自己根据项目关键词自己选择平台。
6 因为文章发布时间和您阅读文章时间存在时间差,所以有些项目红利期可能已经过了,能不能赚钱需要自己判断。
7 本网站仅做资源分享,不做任何收益保障,创业公司上收费几百上千的项目我免费分享出来的,希望大家可以认真学习。
8 本站所有资料均来自互联网公开分享,并不代表本站立场,如不慎侵犯到您的版权利益,请联系79283999@qq.com删除。

本站资料仅供学习交流使用请勿商业运营,严禁从事违法,侵权等任何非法活动,否则后果自负!
THE END
喜欢就支持一下吧
点赞5赞赏 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容