这篇文章主要讲解了“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的互斥锁怎么使用这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。