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 标准库
- 有用的资源
- 符号索引
- 注释
tss_create
定义于头文件 <threads.h>
|
||
int tss_create( tss_t* tss_key, tss_dtor_t destructor ); |
(C11 起) | |
创建新的线程特定存储关键,并将它存储于 tss_key
所指向的对象。尽管不同线程可能使用相同的关键值,由 tss_set 绑定到关键的值在每个线程基础上维护,并且在调用方线程的生命中保持存在。
所有既存线程中,新建的关键被关联到值 NULL ,而在创建线程时,将所有 TSS 关键关联的值被初始化为 NULL 。
若 destructor
不是空指针,则亦关联在 thrd_exit (但不是 tss_delete 且不是在以 exit 终止程序时)释放存储时调用的析构器。
在线程特定存储的析构器内调用 tss_create
导致未定义行为。
参数
tss_key | - | 指向要存储新的线程特定存储关键的内存位置的指针 |
destructor | - | 指向要在线程退出时调用的函数的指针 |
注意
此函数的 POSIX 等价版本是 pthread_key_create 。
返回值
若成功则为 thrd_success ,否则为 thrd_error 。
示例
本节未完成 原因:改进,最好为启发寻找 POSIX 示例 |
int thread_func(void *arg) { tss_t key; if (thrd_success == tss_create(&key, free)) { tss_set(key, malloc(4)); // 在 TSS 上存储指针 // ... } } // 对 TSS 上存储的指针调用 free()
引用
- C11 standard (ISO/IEC 9899:2011):
- 7.26.6.1 The tss_create function (p: 386)