constexpr T
fetch_max(difference_type operand,
memory_order order = memory_order_seq_cst
) noexcept; // (1) C++26
概要
最大値を設定・取得する。
この関数は、*thisが保持する値とoperandの大きい方を求め、その値をthisに保持させた上でその値を返す。
テンプレートパラメータ制約
- (1) :
std::atomic<T*>の場合、型Tがオブジェクト型であること。型Tがvoid*や関数ポインタであってはならない
効果
orderで指定されたメモリオーダーにしたがって、std::max()アルゴリズムのように*thisが保持する値とoperandの最大値を求めて、その値をthisに保持させ、その値を返す
例外
投げない
備考
- この関数は、
atomicクラスの整数型、浮動小数点数型、ポインタに対する特殊化で定義される - 浮動小数点数型
std::fmaximum_num()関数と同様の動作をするが、以下の点で異なる:
- ポインタ型
- ポインタが異なる完全型オブジェクトを指している場合、
<演算子による比較は狭義の弱順序を確立しない
- ポインタが異なる完全型オブジェクトを指している場合、
例
#include <iostream>
#include <atomic>
int main()
{
std::atomic<int> x(2);
int ret = x.fetch_max(3);
std::cout << ret << std::endl;
std::cout << x.load() << std::endl;
}
出力
3
3
バージョン
言語
- C++26