命名空间
变体
操作

std::atomic_ref<T>::fetch_add

来自 cppreference.cn
< cpp‎ | atomic‎ | atomic ref
 
 
并发支持库
线程
(C++11)
(C++20)
this_thread 命名空间
(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++11)
(C++11)
(C++11)
(C++11)
安全回收
(C++26)
危险指针
原子类型
(C++11)
(C++20)
原子类型的初始化
(C++11)(C++20 中已弃用)
(C++11)(C++20 中已弃用)
内存排序
(C++11)(C++26 中已弃用)
原子操作的自由函数
原子标志的自由函数
 
 
仅当 T 是除 cv bool 之外的算术类型或对象指针类型时提供
value_type fetch_add( difference_type arg,

                      std::memory_order order =

                          std::memory_order_seq_cst ) const noexcept;
(C++26 起为 constexpr)

原子地将 *ptr 所引用的当前值替换为该值与 arg 进行算术加法的结果。此操作是读-修改-写操作。内存受 order 值的影响。

  • 对于有符号整数类型,算术运算定义为使用二的补码表示。没有未定义的结果。
  • 对于浮点类型,生效的 浮点环境 可能与调用线程的浮点环境不同。该操作不必符合相应的 std::numeric_limits 特性,但鼓励这样做。如果结果不是其类型可表示的值,则结果是未指定的,但操作本身没有未定义行为。
  • 对于指针类型,结果可能是未定义地址,但操作否则没有未定义行为。

此重载仅在 std::is_const_v<T>false 时参与重载决议。

目录

[编辑] 参数

arg - 算术加法的另一个参数
顺序 - 要强制执行的内存顺序约束

[编辑] 返回值

该函数生效前,由 *ptr 引用的值。

[编辑] 示例

[编辑] 缺陷报告

下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。

缺陷报告 应用于 发布时的行为 正确的行为
LWG 3508
(P3323R1)
C++20 fetch_addconst T 无意义 限制为只接受非 const T