C++11多线程(五):std::lock_guard类的用法

70 篇文章 327 订阅 ¥99.90 ¥299.90
本文介绍了C++11中的std::lock_guard类,它是一种基于RAII的线程安全机制。lock_guard在构造时自动锁定mutex,并在析构时释放锁,确保即使在异常情况下也能正确解锁,避免了死锁的问题。通过示例代码对比了使用lock_guard前后的不同,展示了其在防止资源泄露和提高并发安全性方面的优势。
摘要由CSDN通过智能技术生成

        lock_guard类位于mutex头文件下,使用前需要包含如下语句:

#include<mutex>
using namespace std;

        std::lock_guard类采用RAII手法管理某个锁对象,启动能是在对象构造时将mutex加锁,无需手动调用lock()方法,析构时对mutex解锁,这样保证在异常的情况下mutex可以在lock_guard对象析构时被解锁,不会阻塞其它线程获取mutex.

        lock_guard最大的特点就是安全易于使用,通过lock_guard对象管理的mutex哪怕异常抛出的时候也可以正确的解锁。

        例如如下代码,我们使用原生mutex, 线程A当i==3时,抛出异常,此时A处于异常,mutex没有被解锁,B线程死锁无法执行,程序被阻塞卡死。


                
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

令狐掌门

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值