mtx_timedlock

mtx_timedlock

在头文件中定义
int mtx_timedlock(mtx_t * restrict mutex,const struct timespec * restrict time_point);(自C11以来)

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

如果当前线程已经锁定了互斥锁并且互斥锁不是递归的,则该行为是未定义的。

如果互斥量不支持超时,则行为未定义。

先前对同一个互斥体上的 mtx_unlock 进行同步 - 使用此操作(如果此操作成功),并且对任何给定互斥体的所有锁定/解锁操作形成单个总体顺序(类似于原子的修改顺序)。

参数

mux-指向要锁定的互斥体的指针
time_point -指向等待的超时时间

返回值

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

参考

  • C11标准(ISO / IEC 9899:2011):

扩展内容

mtx_lock(C11)阻塞直到锁定一个互斥量(函数)
mtx_trylock(C11)锁定互斥或返回,如果已锁定(功能)
mtx_unlock(C11)解锁互斥锁(功能)

| try_lock_until 的 C ++文档 |