十二 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时间