【C++】Mutex

学习Mutex首先需要了解互斥锁的概念,详情见之前的文章。

Mutex类就是C++中实现互斥锁的类,互斥锁有可重入和不可重入之分:

mutex是不可重入的互斥锁,recursive_mutex是可重入的互斥锁;

加上上锁时间的限定后,就有了另外两个互斥锁:mutex_timed, recursive_timed_mutex,分别是可重入/不可重入的互斥锁。

 

互斥锁的操作有:

上锁 lock 如果mutex未上锁,则将其上锁。否则如果已经其它线程lock,则阻塞当前线程。

上锁 try_lock 如果mutex未上锁,则将其上锁。否则返回false,并不阻塞当前线程。

解锁 unlock  如果mutex被当前线程锁住,则将其解锁。否则,是未定义的行为。

timed_mutex会多这么两种操作:

try_lock_for(duration) 如果timed_mutex未上锁,则将其上锁,否则阻塞当前线程,但最长只阻塞duration表示的时间段。

try_lock_until(time_point) 如果timed_mutex未上锁,则将其上锁,否则阻塞当前线程,但最长只会阻塞到time_point表示的时间点就不再阻塞。

try_lock_for/until可以检测到死锁的出现,这是目前想到的一种用途。

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C++中的mutex(互斥量)用于实现线程之间的互斥访问,以确保在同一时间只有一个线程可以访问共享资源。引用\[1\]中的代码展示了mutex的用法。在这个例子中,使用了std::mutex类来创建一个互斥量对象mtx。在print_block函数中,通过调用mtx.lock()和mtx.unlock()来实现对临界区的互斥访问。这样可以确保在一个线程访问临界区时,其他线程无法同时访问。 另外,C++11还引入了std::recursive_mutex类,它与std::mutex类似,但允许同一个线程多次对互斥量进行加锁。这在某些情况下可以避免死锁问题。引用\[3\]中的代码展示了std::recursive_mutex的用法。在这个例子中,使用了std::recursive_mutex类来创建一个递归互斥量对象mtx。在func1和func2函数中,通过调用mtx.lock()和mtx.unlock()来实现对临界区的互斥访问。同时,由于使用了递归互斥量,func2函数可以在func1函数中被多次调用而不会导致死锁。 总结来说,C++中的mutex用于实现线程之间的互斥访问,确保在同一时间只有一个线程可以访问共享资源。通过调用lock()和unlock()函数来实现对临界区的互斥访问。同时,C++11还引入了递归互斥量std::recursive_mutex,允许同一个线程多次对互斥量进行加锁,以避免死锁问题。 #### 引用[.reference_title] - *1* *2* [c++ mutex](https://blog.csdn.net/fuhanghang/article/details/114076161)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [C++mutex的使用](https://blog.csdn.net/sinat_31608641/article/details/107733436)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值