C++11的互斥锁怎么使用

这篇文章主要讲解了“C++11的互斥锁怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C++11的互斥锁怎么使用”吧!

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

感谢各位的阅读,以上就是“C++11的互斥锁怎么使用”的内容了,经过本文的学习后,相信大家对C++11的互斥锁怎么使用这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!