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_free
がtrue
であること
- C++20 :
戻り値
以下と等価の式により、演算結果の値が返る:
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
処理系
- Clang: 3.2 ✅
- GCC: 4.7.0 ✅
- Visual C++: 2012 ✅, 2013 ✅
関連項目
参照
- P0020R6 Floating Point Atomic
- C++20での、浮動小数点数版の追加
- P1831R1 Deprecating
volatile
: library- C++20での、
volatile
版への制約追加
- C++20での、