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

履歴 編集

function template
<atomic>

std::atomic_store_or(C++26)

namespace std {
  template <class T>
  void
    atomic_store_or(
      volatile atomic<T>* object,
      typename atomic<T>::difference_type operand) noexcept; // (1) C++26

  template <class T>
  constexpr void
    atomic_store_or(
      atomic<T>* object,
      typename atomic<T>::difference_type operand) noexcept; // (2) C++26
}

概要

値を読み込まずにアトミックに値をORする。

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

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

  • Tが整数型であること
  • (1) :
    • atomic<T>::is_always_lock_freetrueであること

事前条件

効果

memory_order_seq_cstのメモリオーダーにしたがって、現在の値にoperandをORした値でアトミックに置き換える

戻り値

なし

例外

投げない

備考

  • 符号付き整数型に対しては、符号なし整数型に変換されたかのようにしたあと演算が行われ、結果は符号付き整数型になる。未定義動作はない

#include <print>
#include <atomic>

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

  std::atomic_store_or(&x, 0b0101);

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

出力

0b0101

バージョン

言語

  • C++26

処理系

参照