std::condition_variable的wait_until函数超时没有获取到锁会不会执行

 1.C++11中std::condition_variable的使用

wait_for()

    template<typename _Clock, typename _Duration, typename _Predicate>
      bool
      wait_until(unique_lock<mutex>& __lock,
         const chrono::time_point<_Clock, _Duration>& __atime,
         _Predicate __p)
      {
    while (!__p())

//lsd 超时就会解除阻塞吗,那没获取锁不是资源竞争了????
      if (wait_until(__lock, __atime) == cv_status::timeout)
        return __p();
    return true;
      }

 template<typename _Rep, typename _Period, typename _Predicate>
      bool
      wait_for(unique_lock<mutex>& __lock,
           const chrono::duration<_Rep, _Period>& __rtime,
           _Predicate __p)
      {
    using __dur = typename __steady_clock_t::duration;
    auto __reltime = chrono::duration_cast<__dur>(__rtime);
    if (__reltime < __rtime)
      ++__reltime;
    return wait_until(__lock, __steady_clock_t::now() + __reltime,
              std::move(__p));
      }

上面疑问验证结论为:Duration timeout后必须要获取到锁后才能解除阻塞,要是一直没有获取到

锁将会一直在此阻塞,等待超时前的时间范围内获取到notify_*(通知锁可用),如果获取到锁,

才会判断条件。所以wait_for在等待的时间会大于timeout的设置时间(一直没有获得锁和notify_*)

C++11中std::condition_variable的使用_fengbingchun的博客-CSDN博客

std::condition_variable.wait()的用法和设计缺陷带来的坑_std::condition_variable wait_杂质想当杂志的博客-CSDN博客

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值