Chinaunix首页 | 论坛 | 博客
  • 博客访问: 910838
  • 博文数量: 299
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 2493
  • 用 户 组: 普通用户
  • 注册时间: 2014-03-21 10:07
个人简介

Linux后台服务器编程。

文章分类

全部博文(299)

文章存档

2015年(2)

2014年(297)

分类: C/C++

2014-11-06 10:00:48

简单的说:

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;
  }

阅读(6754) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~