mtx_timedlock

< c‎ | thread
定义于头文件 <threads.h>
int mtx_timedlock( mtx_t *restrict mutex,
                   const struct timespec *restrict time_point );
(C11 起)

阻塞当前线程,直到 mutex 所指向的互斥被锁,或直到抵达 time_point 所指向的基于 TIME_UTC 的时间点。

若当前线程已经锁定该互斥且该互斥非递归,则行为未定义。

若该互斥不支持时限,则行为未定义。

先前在同一互斥上对 mtx_unlock 的调用同步于此操作(若此操作成功),而且任何给定的互斥上的所有锁定/解锁组成单独全序(类似原子对象上的修改顺序)。

参数

mutex - 指向要锁定的互斥的指针
time_point - 指向要等待到的时限时间点的指针

返回值

若成功则为 thrd_success ,若已在锁定互斥前抵达时限则为 thrd_timedout ,若出现错误则为 thrd_error

引用

  • C11 standard (ISO/IEC 9899:2011):
  • 7.26.4.4 The mtx_timedlock function (p: 381-382)

参阅

阻塞到锁定互斥为止
(函数)
锁定互斥,若已锁定则返回而不阻塞
(函数)
解锁互斥
(函数)