tss_create
来自 cppreference.com
定义在头文件 <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)); // stores a pointer on TSS // ... } } // calls free() for the pointer stored on TSS
[编辑] 参考文献
- C17 标准 (ISO/IEC 9899:2018)
- 7.26.6.1 tss_create 函数 (p: 281-282)
- C11 标准 (ISO/IEC 9899:2011)
- 7.26.6.1 tss_create 函数 (p: 386)