如何使用lock_guard

原创 2018年04月17日 12:40:43

lock_gurad 是c++11 提供的一个新类,是一个区域锁, 只在作用域内起作用, 出了作用域就自动解锁。

看起来应该是比较简单的,但是异常配合起来使用就需要多加注意。

下面的代码是cplusplus.com 提供的sample。

这个sample的本意是启动10个线程,每个线程对1个数字判断奇偶, 

如果是偶数就打印 “x is even”(x 是要判断的数字),如果是奇数就打印[exception caught]。

但由于sample 中,  std::lock_guard<std::mutex> lck (mtx) 是在try 的作用域中打印的,

一旦print_even 抛出异常,由catch 捕获到,luck就将解锁。 

有时候,不同线程的 std::cout << "[exception caught]\n"; 和 std::cout << x << " is even\n";

会同时运行, 这样导致 打印出现混乱。

例如:

[6e xicse petvieonn

 caught]

[exception caught]

2 is even

8 is even

4 is even

[exception caught]

[exception caught]

[exception caught]

10 is even

将 std::lock_guard<std::mutex> lck (mtx);

 从try 中移到 try 范围外就没问题了。




在函数 print_thread_id 中在try 中调用 

实际coding , 应该需要判断一下 异常处理和try 中的代码是否会有冲突,

如果没有则sample code  是没问题的, 如果有 还要另想其他方法。


// lock_guard example

#include <iostream>       // std::cout

#include <thread>         // std::thread

#include <mutex>          // std::mutex, std::lock_guard

#include <stdexcept>      // std::logic_error


std::mutex mtx;


void print_even (int x) {

  if (x%2==0) std::cout << x << " is even\n";

  else throw (std::logic_error("not even"));

}


void print_thread_id (int id) {

  std::lock_guard<std::mutex> lck (mtx);

  try {

    // using a local lock_guard to lock mtx guarantees unlocking on destruction / exception:

    //std::lock_guard<std::mutex> lck (mtx);

    print_even(id);

  }

  catch (std::logic_error&) {

    std::cout << "[exception caught]\n";

  }

}


int main ()

{

  std::thread threads[10];

  // spawn 10 threads:

  for (int i=0; i<10; ++i)

    threads[i] = std::thread(print_thread_id,i+1);


  for (auto& th : threads) th.join();


  return 0;

}

~                                                                                                                                                                                                         

~                

C++多线程笔记:使用std::lock_guard实现对共享数据的保护

使用std::lock_guard实现对共享数据的保护,可使用如下简单实现: class my_test_mutex { public: void add_to_list(int new...
  • zxw_tiantan
  • zxw_tiantan
  • 2017-02-17 15:48:25
  • 531

C++11之lock_guard学习总结和代码实例

std::lock_gurad 是 C++11 中定义的模板类。定义如下:template class lock_guard { // class with destructor ...
  • haolipengzhanshen
  • haolipengzhanshen
  • 2016-07-27 22:47:08
  • 679

std::mutex 和 std::lock_guard 小例子

参考:http://stackoverflow.com/questions/21771860/how-to-make-sure-locker-be-unlock-in-c-which-solution...
  • yasi_xi
  • yasi_xi
  • 2014-02-14 17:04:06
  • 11439

C++11 mutex方便的自解锁lock_guard

 下面是cpprefrence里的使用mutex的代码。 #include #include #include #include #include #include ...
  • xiaoyafang123
  • xiaoyafang123
  • 2017-01-06 14:27:25
  • 4312

C++11多线程之std::lock_guard

翻译了cppreference上的std::lock_guard一文。
  • nirendao
  • nirendao
  • 2016-03-14 22:22:51
  • 7240

线程自动加锁与自动解锁:lock_guard & unique_lock

#define N 1000000 mutex g_mutex; void add(int *p) { for (int i = 0; i < N; i++) { unique_lockulk...
  • zhouruifu2015
  • zhouruifu2015
  • 2015-08-22 01:03:35
  • 1516

boost::lock_guard 线程同步

boost文档汉化项目地址:http://code.google.com/p/boost-doc-zh/ 线程同步     使用线程肯定逃避不了共享资源的同步问题。   ...
  • yockie
  • yockie
  • 2013-04-23 11:27:16
  • 4979

lock_guard和unique_lock的区别

C++11中有一个区域锁lock_guard,还有第二个区域锁unique_lock。     区域锁lock_guard使用起来比较简单,除了构造函数外没有其他member function,...
  • GyafdxIs
  • GyafdxIs
  • 2015-11-03 19:39:00
  • 2129

自解锁lock_guard

今天遇到lock_guard,大概学习了一下,先贴出源码。 // LOCKS template class lock_guard { // class with destructor that...
  • allen807733144
  • allen807733144
  • 2017-06-22 14:42:53
  • 601
收藏助手
不良信息举报
您举报文章:如何使用lock_guard
举报原因:
原因补充:

(最多只允许输入30个字)