std::atomic_ref<T>::fetch_add
来自 cppreference.com
< cpp | atomic | atomic ref
仅 atomic_ref<Integral> 和 atomic_ref<Floating> 模板特化的成员 |
||
T fetch_add( T arg, std::memory_order order = std::memory_order_seq_cst ) const noexcept; |
(1) | (自 C++20 起) |
仅 atomic_ref<T*> 模板特化的成员 |
||
T* fetch_add( std::ptrdiff_t arg, std::memory_order order = std::memory_order_seq_cst ) const noexcept; |
(2) | (自 C++20 起) |
原子地将引用对象的当前值替换为值和 arg 的算术加法结果。此操作是读-修改-写操作。内存根据 order 的值进行影响。
对于有符号整型,算术定义为使用二进制补码表示。没有未定义的结果。
对于浮点型,实际生效的 浮点环境 可能与调用线程的浮点环境不同。该操作不必符合相应的 std::numeric_limits 特性,但鼓励这样做。如果结果不是其类型可以表示的值,则结果未指定,但操作本身没有未定义的行为。
对于 T*
类型,结果可能是未定义的地址,但操作本身没有未定义的行为。如果 T
不是对象类型,则程序格式错误。
[编辑] 参数
arg | - | 算术加法的另一个参数 |
order | - | 要强制执行的内存排序约束 |
[编辑] 返回值
引用对象的当前值,该值紧接在执行此函数之前的效果。
[编辑] 示例
此部分不完整 原因:没有示例 |