- atomic[meta header]
- std[meta namespace]
- function template[meta id-type]
- cpp26[meta cpp]
namespace std {
template <class T>
void
atomic_store_add(
volatile atomic<T>* object,
typename atomic<T>::difference_type operand) noexcept; // (1) C++26
template <class T>
constexpr void
atomic_store_add(
atomic<T>* object,
typename atomic<T>::difference_type operand) noexcept; // (2) C++26
}- atomic[link /reference/atomic/atomic.md]
値を読み込まずにアトミックに値を加算する。
この関数は、atomic_fetch_add()と異なり、現在の (古い) 値を読み込むことなく現在の値に演算を行うため、高速に動作する。ただし変更前の古い値は戻り値として取得できない。
- 型
Tがオブジェクト型であること。型Tがvoid*や関数ポインタであってはならない - (1) :
atomic<T>::is_always_lock_freeがtrueであること
orderは、以下のいずれかであること
memory_order_seq_cstのメモリオーダーにしたがって、現在の値にoperandを加算した値でアトミックに置き換える
なし
投げない
符号付き整数型に対しては、2の補数表現による演算が行われ、未定義動作はない。アドレス型に関しては結果として未定義アドレスになる場合があるが、それ以外の未定義動作はない。
#include <iostream>
#include <atomic>
int main()
{
std::atomic<int> x(3);
std::atomic_store_add(&x, 2);
std::cout << x.load() << std::endl;
}- std::atomic_store_add[color ff0000]
- x.load()[link /reference/atomic/atomic/load.md]
5
- C++26
- Clang: 21 [mark noimpl]
- GCC: 15 [mark noimpl]
- Visual C++: 2022 Update 13 [mark noimpl]