Skip to content

Latest commit

 

History

History
92 lines (64 loc) · 2.33 KB

File metadata and controls

92 lines (64 loc) · 2.33 KB

store_or

  • atomic[meta header]
  • std[meta namespace]
  • atomic[meta class]
  • function[meta id-type]
  • cpp26[meta cpp]
void
  store_or(difference_type operand,
            memory_order order = memory_order_seq_cst
            ) volatile noexcept;                      // (1) C++26

constexpr void
  store_or(difference_type operand,
            memory_order order = memory_order_seq_cst
            ) noexcept;                               // (2) C++26
  • memory_order[link /reference/atomic/memory_order.md]
  • memory_order_seq_cst[link /reference/atomic/memory_order.md]

概要

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

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

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

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

事前条件

効果

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

戻り値

なし

例外

投げない

備考

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

基本的な使い方

#include <print>
#include <atomic>

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

  x.store_or(0b0101);

  std::println("0b{:04b}", x.load());
}
  • store_or[color ff0000]
  • x.load()[link load.md]

出力

0b1101

バージョン

言語

  • C++26

処理系

参照