命名空间
变体
操作

并发支持库

来自 cppreference.cn
< c

C 语言内置支持线程、原子操作、互斥体、条件变量和线程局部存储。

这些特性是可选提供的

  • 如果编译器定义了宏常量 __STDC_NO_THREADS__,则头文件 <threads.h> 及其提供的所有名称将不被提供;
  • 如果编译器定义了宏常量 __STDC_NO_ATOMICS__,则头文件 <stdatomic.h> 及其提供的所有名称将不被提供。

另请参阅 _Atomic 类型说明符和限定符

目录

[编辑] 线程

在头文件 <threads.h> 中定义
thrd_t 实现定义的完整对象类型,用于标识一个线程 [编辑]
创建线程
(函数) [编辑]
检查两个标识符是否引用同一个线程
(函数) [编辑]
获取当前线程标识符
(函数) [编辑]
暂停调用线程的执行指定时间
(函数) [编辑]
让出当前时间片
(函数) [编辑]
终止调用线程
(函数) [编辑]
分离线程
(函数) [编辑]
阻塞直到线程终止
(函数) [编辑]
指示线程错误状态
(常量) [编辑]
thrd_start_t
(C11)
函数指针类型 int(*)(void*) 的 typedef,由 thrd_create 使用
(typedef) [编辑]

[编辑] 原子操作

在头文件 <stdatomic.h> 中定义
原子类型上的操作
指示给定的原子类型是否是无锁的
(宏常量) [编辑]
指示原子对象是否是无锁的
(函数) [编辑]
在原子对象中存储值
(函数) [编辑]
从原子对象中读取值
(函数) [编辑]
与原子对象的值交换
(函数) [编辑]
如果旧值是期望的,则与原子对象交换值,否则读取旧值
(函数) [编辑]
原子加法
(函数) [编辑]
原子减法
(函数) [编辑]
原子位或
(函数) [编辑]
原子位异或
(函数) [编辑]
原子位与
(函数) [编辑]
标志类型和操作
无锁原子布尔标志
(结构体)[编辑]
将 atomic_flag 设置为 true 并返回旧值
(函数) [编辑]
将 atomic_flag 设置为 false
(函数) [编辑]
初始化
初始化现有原子对象
(函数) [编辑]
(C11)(C17 中已弃用)(C23 中已移除)
初始化新的原子对象
(函数宏) [编辑]
初始化新的 atomic_flag
(宏常量) [编辑]
内存同步顺序
定义内存排序约束
(枚举) [编辑]
memory_order_consume 打断依赖链
(函数宏) [编辑]
通用内存排序依赖的屏障同步原语
(函数) [编辑]
线程与在同一线程中执行的信号处理程序之间的屏障
(函数) [编辑]
便捷类型别名
类型定义名称 完整类型名称
atomic_bool (C11) _Atomic _Bool(直到 C23)_Atomic bool(自 C23 起)
atomic_char (C11) _Atomic char
atomic_schar (C11) _Atomic signed char
atomic_uchar (C11) _Atomic unsigned char
atomic_short (C11) _Atomic short
atomic_ushort (C11) _Atomic unsigned short
atomic_int (C11) _Atomic int
atomic_uint (C11) _Atomic unsigned int
atomic_long (C11) _Atomic long
atomic_ulong (C11) _Atomic unsigned long
atomic_llong (C11) _Atomic long long
atomic_ullong (C11) _Atomic unsigned long long
atomic_char8_t (C23) _Atomic char8_t
atomic_char16_t (C11) _Atomic char16_t
atomic_char32_t (C11) _Atomic char32_t
atomic_wchar_t (C11) _Atomic wchar_t
atomic_int_least8_t (C11) _Atomic int_least8_t
atomic_uint_least8_t (C11) _Atomic uint_least8_t
atomic_int_least16_t (C11) _Atomic int_least16_t
atomic_uint_least16_t (C11) _Atomic uint_least16_t
atomic_int_least32_t (C11) _Atomic int_least32_t
atomic_uint_least32_t (C11) _Atomic uint_least32_t
atomic_int_least64_t (C11) _Atomic int_least64_t
atomic_uint_least64_t (C11) _Atomic uint_least64_t
atomic_int_fast8_t (C11) _Atomic int_fast8_t
atomic_uint_fast8_t (C11) _Atomic uint_fast8_t
atomic_int_fast16_t (C11) _Atomic int_fast16_t
atomic_uint_fast16_t (C11) _Atomic uint_fast16_t
atomic_int_fast32_t (C11) _Atomic int_fast32_t
atomic_uint_fast32_t (C11) _Atomic uint_fast32_t
atomic_int_fast64_t (C11) _Atomic int_fast64_t
atomic_uint_fast64_t (C11) _Atomic uint_fast64_t
atomic_intptr_t (C11) _Atomic intptr_t
atomic_uintptr_t (C11) _Atomic uintptr_t
atomic_size_t (C11) _Atomic size_t
atomic_ptrdiff_t (C11) _Atomic ptrdiff_t
atomic_intmax_t (C11) _Atomic intmax_t
atomic_uintmax_t (C11) _Atomic uintmax_t

[编辑] 互斥

在头文件 <threads.h> 中定义
mtx_t 互斥体标识符 [编辑]
创建互斥体
(函数) [编辑]
阻塞直到锁定互斥体
(函数) [编辑]
阻塞直到锁定互斥体或超时
(函数) [编辑]
锁定互斥体,如果已锁定则不阻塞返回
(函数) [编辑]
解锁互斥体
(函数) [编辑]
销毁互斥体
(函数) [编辑]
定义互斥体类型
(枚举) [编辑]
一次调用
只调用一次函数
(函数) [编辑]

[编辑] 条件变量

在头文件 <threads.h> 中定义
cnd_t 条件变量标识符
创建条件变量
(函数) [编辑]
解除阻塞在条件变量上阻塞的一个线程
(函数) [编辑]
解除阻塞在条件变量上阻塞的所有线程
(函数) [编辑]
在条件变量上阻塞
(函数) [编辑]
在条件变量上阻塞,带有超时
(函数) [编辑]
销毁条件变量
(函数) [编辑]

[编辑] 线程局部存储

在头文件 <threads.h> 中定义
(C11 起)(C23 中移除)
存储类说明符 _Thread_local 的便捷宏
(关键字宏) [编辑]
tss_t 线程局部存储指针 [编辑]
析构函数被调用的最大次数
(宏常量) [编辑]
tss_dtor_t
(C11)
函数指针类型 void(*)(void*),用于 TSS 析构函数
(typedef) [编辑]
使用给定析构函数创建线程局部存储指针
(函数) [编辑]
从线程局部存储读取
(函数) [编辑]
写入线程局部存储
(函数) [编辑]
释放给定线程局部指针持有的资源
(函数) [编辑]

[编辑] 保留标识符

在 C 标准的未来修订中

  • cnd_mtx_thrd_tss_ 开头并后跟小写字母的函数名、类型名和枚举常量可能会添加到 <threads.h> 头文件中的声明中;
  • ATOMIC_ 开头并后跟大写字母的宏可能会添加到 <stdatomic.h> 头文件中定义的宏中;
  • atomic_memory_ 开头并后跟小写字母的 typedef 名称可能会添加到 <stdatomic.h> 头文件中的声明中;
  • memory_order_ 开头并后跟小写字母的枚举常量可能会添加到 <stdatomic.h> 头文件中 memory_order 类型的定义中;
  • atomic_ 开头并后跟小写字母的函数名可能会添加到 <stdatomic.h> 头文件中的声明中。

保留的函数名标识符总是 可能(自 C23 起) 保留用作具有外部链接的标识符,而此处列出的其他标识符在包含 <stdatomic.h>可能(自 C23 起) 被保留。

声明、定义或 #undef 这些标识符会导致未定义行为,如果它们由标准或实现提供(自 C23 起)。可移植程序不应使用这些标识符。

[编辑] 参考文献

  • C23 标准 (ISO/IEC 9899:2024)
  • 7.17 原子操作 <stdatomic.h> (p: TBD)
  • 7.26 线程 <threads.h> (p: TBD)
  • 7.31.8 原子操作 <stdatomic.h> (p: TBD)
  • 7.31.15 线程 <threads.h> (p: TBD)
  • C17 标准 (ISO/IEC 9899:2018)
  • 7.17 原子操作 <stdatomic.h> (p: 200-209)
  • 7.26 线程 <threads.h> (p: 274-283)
  • 7.31.8 原子操作 <stdatomic.h> (p: 332)
  • 7.31.15 线程 <threads.h> (p: 333)
  • C11 标准 (ISO/IEC 9899:2011)
  • 7.17 原子操作 <stdatomic.h> (p: 273-286)
  • 7.26 线程 <threads.h> (p: 376-387)
  • 7.31.8 原子操作 <stdatomic.h> (p: 455-456)
  • 7.31.15 线程 <threads.h> (p: 456)

[编辑] 另请参阅

C++ 文档,关于 并发支持库

[编辑] 外部链接

GNU GCC Libc Manual: ISO C Mutexes