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

一、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时间
原文地址:https://www.cnblogs.com/pacino12134/p/11271167.html