void
store_fminimum_num(difference_type operand,
memory_order order = memory_order_seq_cst
) volatile noexcept; // (1) C++26
constexpr void
store_fminimum_num(difference_type operand,
memory_order order = memory_order_seq_cst
) noexcept; // (2) C++26
概要
値を読み込まずに最小値を設定する。
この関数は、*thisが保持する値とoperandの小さい方を求め、その値をthisに保持させる。
この関数は、fetch_fminimum_num()と異なり、現在の (古い) 値を読み込むことなく現在の値に演算を行うため、高速に動作する。ただし変更前の古い値は戻り値として取得できない。
テンプレートパラメータ制約
std::atomic<T*>の場合、型Tがオブジェクト型であること。型Tがvoid*や関数ポインタであってはならない- (1) :
atomic<T>::is_always_lock_freeがtrueであること
事前条件
orderは、以下のいずれかであること
効果
orderで指定されたメモリオーダーにしたがって、*thisが保持する値とoperandの最小値を求めて、その値でアトミックに置き換える
戻り値
なし
例外
投げない
備考
- この関数は、
atomicクラスの浮動小数点数型に対する特殊化で定義される - 浮動小数点数型
std::fminimum_num()関数と同様の動作をする
例
#include <iostream>
#include <atomic>
int main()
{
std::atomic<int> x(2);
x.store_fminimum_num(3);
std::cout << x.load() << std::endl;
}
出力
2
バージョン
言語
- C++26
処理系
- Clang: 21 ❌
- GCC: 15 ❌
- Visual C++: 2022 Update 13 ❌