最終更新日時(UTC):
が更新

履歴 編集

function
<atomic>

std::atomic::operator+=(C++11)

T operator+=(T operand) volatile noexcept; // (1) C++11
T operator+=(T operand) noexcept;          // (2) C++11

概要

加算を行う

テンプレートパラメータ制約

  • (1) :
    • C++20 : atomic<T>::is_always_lock_freetrueであること

戻り値

以下と等価の式により、演算結果の値が返る:

return fetch_add(operand) + operand;

例外

投げない

備考

  • この関数は、atomicクラスの整数型、浮動小数点数型 (C++20)、ポインタに対する特殊化で定義される
  • 整数型
    • 符号付き整数型に対しては、2の補数表現による演算が行われ、未定義動作はない
  • 浮動小数点数型 (C++20)
    • 演算結果が、その型で表現できない値であった場合、結果は未規定値になる。ただしその操作によって未定義動作は起こらない
    • 浮動小数点数型に対する操作はstd::numeric_limits<floating-point>トレイトに準拠する
    • 浮動小数点数型に対するアトミック操作の浮動小数点環境は、呼び出しスレッドの浮動小数点環境とは異なる可能性がある
  • ポインタ型
    • 結果として未定義アドレスになる場合があるが、それ以外の未定義動作はない

整数の例 (C++11)

#include <iostream>
#include <atomic>

int main()
{
  std::atomic<int> x(3);

  x += 2;

  std::cout << x.load() << std::endl;
}

出力

5

浮動小数点数の例 (C++20)

#include <iostream>
#include <atomic>

int main()
{
  std::atomic<float> x{3.14f};

  x += 1.25f;

  std::cout << x.load() << std::endl;
}

出力

4.39

複数スレッドから加算する例 (C++11)

#include <iostream>
#include <atomic>
#include <thread>

int main()
{
  std::atomic<int> x{0};

  // 複数スレッドで加算を呼んでも、
  // 最終的に全てのスレッドでの加算が処理された値になる
  std::thread t1 {[&x] {
    x += 1;
  }};
  std::thread t2 {[&x] {
    x += 2;
  }};

  t1.join();
  t2.join();

  std::cout << x.load() << std::endl;
}

出力

3

バージョン

言語

  • C++11

処理系

関連項目

参照