C++多线程编程(4):共享锁与互斥锁

🔆 文章首发于我的个人博客:欢迎大佬们来逛逛

文章目录

共享锁

  1. 使用 mutex 进行加锁与开锁
mutex.lock()
...
mutex.unlock()
  1. 使用 lock_guard 实现lock与unlock

lock_guard实际上就是对mutex的封装

class _NODISCARD_LOCK lock_guard { // class with destructor that unlocks a mutex
public:
    using mutex_type = _Mutex;

    explicit lock_guard(_Mutex& _Mtx) : _MyMutex(_Mtx) { // construct and lock
        _MyMutex.lock();
    }

    lock_guard(_Mutex& _Mtx, adopt_lock_t) : _MyMutex(_Mtx) {} // construct but don't lock

    ~lock_guard() noexcept {
        _MyMutex.unlock();
    }

    lock_guard(const lock_guard&)            = delete;
    lock_guard& operator=(const lock_guard&) = delete;

private:
    _Mutex& _MyMutex;
};

互斥锁

  1. 使用 unique_lock 实现互斥锁
std::unique_lock<std::mutex> uLk(m_mutex);
  1. 使用 unique_lock 的 adopt_lock

adopt_lock假设调用一方线程已拥有互斥的所有权

m_mutex.lock(); //首先要加锁
std::unique_lock<std::mutex> uLk(m_mutex, std::adopt_lock);
  1. 使用 unique_lock 的 defer_lock

defer_lock不获得互斥的所有权(或在稍后获得)

std::unique_lock<std::mutex> uLk(m_mutex, std::defer_lock);
uLk.lock();
uLk.unlock();
  1. 使用 unique_lock 的 try_to_lock

try_to_lock尝试获得互斥的所有权而不阻塞

std::unique_lock<std::mutex> uLk(m_mutex, std::try_to_lock);
if (uLk.owns_lock()) {
		...
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Yuleo_

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

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

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

打赏作者

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

抵扣说明:

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

余额充值