C++ 参考手册

位置:首页 > C++ 参考手册 >原子操作库 >std::atomic > std::atomic<T>::fetch_add

仅为 atomic<Integral>(C++11)atomic<Floating>(C++20) 模板特化的成员
(1)
T fetch_add( T arg,
             std::memory_order order = std::memory_order_seq_cst ) noexcept;
T fetch_add( T arg,
             std::memory_order order = std::memory_order_seq_cst ) volatile noexcept;
仅为 atomic<T*> 模板特化的成员
(2)
T* fetch_add( std::ptrdiff_t arg,
              std::memory_order order = std::memory_order_seq_cst ) noexcept;
T* fetch_add( std::ptrdiff_t arg,
              std::memory_order order = std::memory_order_seq_cst ) volatile noexcept;

原子地以值和 arg 的算术加法结果替换当前值。运算是读修改写操作。按照 order 的值影响内存。

对于有符号 Integral 类型,定义算术为使用补码。无未定义结果。

对于浮点类型,有影响的浮点环境可能异于调用方线程的浮点环境。操作不必服从对应的 std::numeric_limits 特性,但鼓励这么做。若结果不是其类型所能表示的值,则结果未指定,但其他情况下操作无未定义行为。

(C++20 起)

对于 T* 类型,结果可能为未定义的地址,但其他情况下运算无未定义行为。

参数

arg - 算术加法的另一参数
order - 强制的内存顺序制约

返回值

*this修改顺序中,立即前趋此函数效应的值。

缺陷报告

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

DR 应用于 出版时的行为 正确行为
P0558R1 C++11 曾容许指向 cv void 或函数的指针 使之为病式

示例

#include <iostream>
#include <thread>
#include <atomic>
 
std::atomic<long long> data;
void do_work()
{
    data.fetch_add(1, std::memory_order_relaxed);
}
 
int main()
{
    std::thread th1(do_work);
    std::thread th2(do_work);
    std::thread th3(do_work);
    std::thread th4(do_work);
    std::thread th5(do_work);
 
    th1.join();
    th2.join();
    th3.join();
    th4.join();
    th5.join();
 
    std::cout << "Result:" << data << '\n';
}

输出:

Result:5

参阅

将非原子值加到原子对象,并获得原子对象的先前值
(函数模板)