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

履歴 編集

function
<atomic>

std::atomic::store_xor(C++26)

void
  store_xor(difference_type operand,
            memory_order order = memory_order_seq_cst
            ) volatile noexcept;                      // (1) C++26

constexpr void
  store_xor(difference_type operand,
            memory_order order = memory_order_seq_cst
            ) noexcept;                               // (2) C++26

概要

値を読み込まずにXOR演算を行う。

この関数は、fetch_xor()と異なり、現在の (古い) 値を読み込むことなく現在の値に演算を行うため、高速に動作する。ただし変更前の古い値は戻り値として取得できない。

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

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

事前条件

効果

orderで指定されたメモリオーダーにしたがって、現在の値にoperandをXORした値でアトミックに置き換える

戻り値

なし

例外

投げない

備考

  • この関数は、atomicクラスの整数型に対する特殊化で定義される
  • 符号付き整数型に対しては、符号なし整数型に変換されたかのようにしたあと演算が行われ、結果は符号付き整数型になる。未定義動作はない

基本的な使い方

#include <print>
#include <atomic>

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

  x.store_xor(0b0101);

  std::println("0b{:04b}", x.load());
}

出力

0b1100

バージョン

言語

  • C++26

処理系

参照