shared_lock and unique_lock

本文详细解释了C++中shared_lock和unique_lock的区别与用途,包括它们如何实现读写锁定,以及在并发编程中的应用。通过实例代码展示了如何正确使用这两种锁以确保线程安全。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

简单的说:

shared_lock是read lock。被锁后仍允许其他线程执行同样被shared_lock的代码。这是一般做读操作时的需要。

unique_lock是write lock。被锁后不允许其他线程执行被shared_lock或unique_lock的代码。在写操作时,一般用这个,可以同时限制unique_lock的写和share_lock的读。

例子:

 

void GetFields(DBFields& _return, const std::wstring& sGUID)  {     printf("GetFields\n"); boost::shared_lock< boost::shared_mutex > xLock( GetMutex(sGUID) );

//用shared_lock, 其他线程不可以执行下面的SetFields(), 但可以同时执行GetFields()

_return = GetDataPtr(sGUID)->m_oFieldData.m_oDBFields;   }


void SetFields(const std::wstring& sGUID, const DBFields& aFields) {

        printf("SetFields\n"); boost::unique_lock< boost::shared_mutex > xLock(  GetMutex(sGUID) );

//用unique_lock, 其他线程一定要等到这个函数结束才可以执行SetFields()或GetFields()。

GetSetDataPtr(sGUID)->m_oFieldData.m_oDBFields = aFields;   }

转载自http://blog.youkuaiyun.com/daraemon418/article/details/7211693

转载于:https://www.cnblogs.com/defen/p/4410232.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值