C 参考手册
- C 语言
- C 关键词
- 预处理器
- C 标准库头文件
- 类型支持
- 程序支持工具
- 变参数函数
- 错误处理
- 动态内存管理
- 日期和时间工具
- 字符串库
- 算法
- 数值
- 文件输入/输出
- 本地化支持
- 原子操作库
- 线程支持库
- thread_local
- thrd_create
- thrd_equal
- thrd_current
- thrd_sleep
- thrd_yield
- thrd_exit
- thrd_detach
- thrd_join
- thrd_success, thrd_timedout, thrd_busy, thrd_nomem, thrd_error
- mtx_init
- mtx_lock
- mtx_timedlock
- mtx_trylock
- call_once, once_flag, ONCE_FLAG_INIT
- mtx_unlock
- mtx_destroy
- mtx_plain, mtx_recursive, mtx_timed
- cnd_init
- cnd_signal
- cnd_broadcast
- cnd_wait
- cnd_timedwait
- cnd_destroy
- TSS_DTOR_ITERATIONS
- tss_create
- tss_get
- tss_set
- tss_delete
- 实验性 C 标准库
- 有用的资源
- 符号索引
- 注释
mtx_timedlock
定义于头文件 <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)
参阅
(C11) |
阻塞到锁定互斥为止 (函数) |
(C11) |
锁定互斥,若已锁定则返回而不阻塞 (函数) |
(C11) |
解锁互斥 (函数) |