原子操作库
来自cppreference.com
< cpp
原子库为细粒度的原子操作提供组件,允许无锁并发编程。涉及同一对象的每个原子操作,相对于任何其他原子操作是不可分的。原子对象不具有数据竞争。
定义于头文件
<atomic> | |
原子类型 | |
(C++11) |
atomic 类模板及其针对布尔、整型和指针类型的特化 (类模板) |
(C++20) |
提供非原子对象上的原子操作 (类模板) |
原子类型上的操作 | |
(C++11) |
检查对该原子类型的操作是否是无锁的 (函数模板) |
(C++11)(C++11) |
原子地以非原子实参替换原子对象的值 (函数模板) |
(C++11)(C++11) |
原子地获得存储于原子对象的值 (函数模板) |
(C++11)(C++11) |
原子地以非原子实参的值替换原子对象的值,并返回该原子对象的旧值 (函数模板) |
原子地比较原子对象和非原子实参的值,若相等则进行 atomic_exchange,若不相等则进行 atomic_load (函数模板) | |
(C++11)(C++11) |
将非原子值加到原子对象,并获得原子对象的先前值 (函数模板) |
(C++11)(C++11) |
从原子对象减去非原子值,并获得原子对象的先前值 (函数模板) |
(C++11)(C++11) |
将原子对象替换为与非原子实参逻辑与的结果,并获得原子对象的先前值 (函数模板) |
(C++11)(C++11) |
将原子对象替换为与非原子实参逻辑或的结果,并获得原子对象的先前值 (函数模板) |
(C++11)(C++11) |
将原子对象替换为与非原子实参逻辑异或的结果,并获得原子对象的先前值 (函数模板) |
(C++20)(C++20) |
阻塞线程直至被提醒且原子值更改 (函数模板) |
(C++20) |
提醒一个在 atomic_wait 中阻塞的线程 (函数模板) |
(C++20) |
提醒所有在 atomic_wait 中阻塞的线程 (函数模板) |
标志类型及操作 | |
(C++11) |
免锁的布尔原子类型 (类) |
原子地设置标志为 true 并返回其先前值 (函数) | |
(C++11)(C++11) |
原子地设置标志值为 false (函数) |
(C++20)(C++20) |
原子地返回标志的值 (函数) |
(C++20)(C++20) |
阻塞线程,直至被提醒且标志更改 (函数) |
(C++20) |
提醒一个在 atomic_flag_wait 中阻塞的线程 (函数) |
(C++20) |
提醒所有在 atomic_flag_wait 中阻塞的线程 (函数) |
初始化 | |
(C++11)(C++20 中弃用) |
对默认构造的原子对象进行非原子初始化 (函数模板) |
(C++11)(C++20 中弃用) |
静态存储期的原子对象的常量初始化 (宏函数) |
(C++11)(C++20 中弃用) |
将 std::atomic_flag 初始化为 false (宏常量) |
内存同步顺序 | |
(C++11) |
为给定的原子操作定义内存顺序约束 (枚举) |
(C++11) |
从 std::memory_order_consume 依赖树移除指定对象 (函数模板) |
(C++11) |
通用的依赖内存顺序的栅栏同步原语 (函数) |
(C++11) |
线程与执行于同一线程的信号处理函数间的栅栏 (函数) |
原子类型的 C 兼容性
定义于头文件
<stdatomic.h> | |
(C++23) |
使得 _Atomic(T) 等同于 std::atomic<T> 的兼容性宏 (宏函数) |
|
(C++23 起) |