【Boost】boost库中thread多线程详解3——细说lock_guard

来源:互联网 发布:g1x mark ii 知乎 编辑:程序博客网 时间:2024/04/28 15:33
boost::lock_guard可以说是一种比boost::unique_lock轻量级的lock, 简单一些场景可以用它就行了。
看看它的源代码也很简单:
[cpp] view plain copy
 print?
  1. template<typename Mutex>  
  2. class lock_guard  
  3. {  
  4. private:  
  5.     Mutex& m;  
  6.   
  7.     explicit lock_guard(lock_guard&);  
  8.     lock_guard& operator=(lock_guard&);  
  9. public:  
  10.     explicit lock_guard(Mutex& m_):  
  11.         m(m_)  
  12.     {  
  13.         m.lock();  
  14.     }  
  15.     lock_guard(Mutex& m_,adopt_lock_t):  
  16.         m(m_)  
  17.     {}  
  18.     ~lock_guard()  
  19.     {  
  20.         m.unlock();  
  21.     }  
  22. };  

      可以看到只有两个public方法,即构造和析构函数,也就是说,使用boost::lock_guard去guard一个mutex,必然是在boost::lock_guard的对象离开其作用域时unlock它所guard的mutex,不提供提前unlock的功能。
      而boost::unique_lock则提供这个功能,除了像boost::lock_guard一样在离开作用域时unlock它guard的mutex外,boost::unique还提供unlock函数,使用者可以手动执行unlock。此外,unique_lock还可以设置超时。
0 0
原创粉丝点击