std::atomic::fetch_add

来自cppreference.com
< cpp‎ | atomic‎ | atomic
 
 
 
 
(1) (C++11 起)
(仅为 atomic<Integral> 模板特化的成员)
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;
(2) (C++11 起)
(仅为 atomic<T*> 模板特化的成员)
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 类型,定义算术为使用补码。无未定义结果。对于 T* 类型,结果可能为未定义的地址,但其他情况下运算无未定义行为。

目录

[编辑] 参数

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

[编辑] 返回值

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

[编辑] 示例

#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

[编辑] 参阅

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