namespace std {
template <class T>
void
atomic_store_xor(
volatile atomic<T>* object,
typename atomic<T>::difference_type operand) noexcept; // (1) C++26
template <class T>
constexpr void
atomic_store_xor(
atomic<T>* object,
typename atomic<T>::difference_type operand) noexcept; // (2) C++26
}
概要
値を読み込まずにアトミックに値をXORする。
この関数は、atomic_fetch_xor()と異なり、現在の (古い) 値を読み込むことなく現在の値に演算を行うため、高速に動作する。ただし変更前の古い値は戻り値として取得できない。
テンプレートパラメータ制約
- 型
Tが整数型であること - (1) :
atomic<T>::is_always_lock_freeがtrueであること
事前条件
orderは、以下のいずれかであること
効果
memory_order_seq_cstのメモリオーダーにしたがって、現在の値にoperandをXORした値でアトミックに置き換える
戻り値
なし
例外
投げない
備考
- 符号付き整数型に対しては、符号なし整数型に変換されたかのようにしたあと演算が行われ、結果は符号付き整数型になる。未定義動作はない
例
#include <print>
#include <atomic>
int main()
{
std::atomic<int> x(0b1001);
std::atomic_store_xor(&x, 0b0101);
std::println("0b{:04b}", x.load());
}
出力
0b1100
バージョン
言語
- C++26
処理系
- Clang: 21 ❌
- GCC: 15 ❌
- Visual C++: 2022 Update 13 ❌