命名空间
变体
操作

cnd_timedwait

来自 cppreference.cn
< c‎ | thread
在头文件 <threads.h> 中定义
int cnd_timedwait( cnd_t* restrict cond, mtx_t* restrict mutex,
                   const struct timespec* restrict time_point );
(C11 起)

原子地解锁 mutex 指向的互斥量,并在 cond 指向的条件变量上阻塞,直到线程被 cnd_signalcnd_broadcast 发出信号,或直到达到 time_point 指向的基于 TIME_UTC 的时间点,或直到发生虚假唤醒。函数返回前会再次锁定互斥量。

如果互斥量尚未被调用线程锁定,则行为是未定义的。

目录

[编辑] 参数

cond - 指向要阻塞的条件变量的指针
mutex - 指向在阻塞期间解锁的互斥量的指针
time_point - 指向指定超时时间的对象指针

[编辑] 返回值

如果成功则为 thrd_success,如果在锁定互斥量之前达到超时时间则为 thrd_timedout,如果发生错误则为 thrd_error

[编辑] 参考

  • C17 标准 (ISO/IEC 9899:2018)
  • 7.26.3.5 The cnd_timedwait function (p: 276-277)
  • C11 标准 (ISO/IEC 9899:2011)
  • 7.26.3.5 The cnd_timedwait function (p: 379-380)

[编辑] 参阅

在条件变量上阻塞
(函数) [编辑]
C++ 文档,关于 condition_variable::wait_until
C++ 文档,关于 condition_variable_any::wait_until