当前位置: 代码迷 >> 综合 >> C++11 std::lock_guard 互斥锁
  详细解决方案

C++11 std::lock_guard 互斥锁

热度:67   发布时间:2024-02-25 07:22:06.0

C++11中加入了线程,引入了多线程,也就伴随着一个多线程资源互斥的操作。对于锁的使用,有一个比较头疼的问题,就是在加锁后,容易忘记解锁,这样程序中可能会造成死锁。C++11中加入了lock_guard,这个的使用,可以让你不用关注解锁!

原理是这样的:这个是利用了C++的特性(析构函数),用法是在函数开始的地方声明一个lock_guard 对象,构造函数中启用加锁,函数结束的时候,这个lock_guard 对象作用域也就结束了,自动析构,析构时会自动释放锁!这样是不是很省心~

 

#include <mutex>    /*std::mutex、 std::lock_guard*/
#include <iostram>std::mutex mutex;int counter = 0;
void testFunc()
{//lock_guard 互斥锁 作用域内上锁std::lock_guard<std::mutex> lockGuard(mutex);//函数体counter++;
} //函数结束时,作用域结束,自动释放int main()
{testFunc();std::cout <<"counter = "<<counter <<std::endl;return 0;
}

 

微信公众号: