首页 > Windows开发 > 详细

十二 windows临界区,其他各种mutex

时间:2019-07-30 17:15:22      阅读:111      评论:0      收藏:0      [点我收藏+]

一、windows临界区

类似于互斥量 == 临界区。

 

二、多次进入临界区

进入临界区(加锁);

离开临界区(解锁);

同一个线程中windows中相同临界区变量代表的临界区进入(entercirticalsection)可以被多次调用(多次进入),别忘了进了几次,就离开临界区几次。c++11不允许同一个线程中lock同一个互斥量多次,否则报异常

 

三、windows自动析构技术

 

四、recursive_mutex递归的独占互斥量

std::mutex独占互斥量,自己lock时,别人lock不了。

recursive_mutex:允许同一个线程同一个互斥量多次被lock,和mutex用法一样。

效率低,更复杂,递归次数有限制,太多可能会报异常

五、带超时的互斥量std::timed_mutex和std::recursive_timed_mutex

以往拿不到锁,就一直卡着,一直等知道拿到锁

带超时的就是拿不到锁,等一段时间,还拿不到继续走下面的代码。

std::lock_guard<std::recursive_mutex> sbguard(my_mutex);
std::chrono::milliseconds timeout(100);//100毫秒
if(my_mutex.try_lock_for(timeout)){
    //等待100毫秒内拿到了锁
    //执行、、、、
    my_mutex.unlock();
}
else{
    //没拿到,休息一下
    std::chrono::microseconds sleeptime(100);//100微妙
    std::this_thread::sleep_for(sleeptime);
}

try_lock_for():参数是一段时间,是等待一段时间,如果拿到了锁或者等待超时没拿到所,都走下去;

try_lock_unit():参数是未来的时间点,在这个未来的时间没到的时间段内,如果拿到了锁,流程走下来,如果到了没拿到所,也走下来;

1 std::chrono::milliseconds timeout(100);//100毫秒
2 if(my_mutex.try_lock_unit(chrono::steady_clock::now() + timeout))
{
//........

};//当前时间点加timeout时间

 

十二 windows临界区,其他各种mutex

原文:https://www.cnblogs.com/pacino12134/p/11271167.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!