std::atomic_ref<T>::compare_exchange_weak, std::atomic_ref<T>::compare_exchange_strong
bool compare_exchange_weak ( value_type& expected, value_type desired, |
(1) | (C++26 以降 constexpr) |
bool compare_exchange_weak ( value_type& expected, value_type desired, |
(2) | (C++26 以降 constexpr) |
bool compare_exchange_strong ( value_type& expected, value_type desired, |
(3) | (C++26 以降 constexpr) |
bool compare_exchange_strong ( value_type& expected, value_type desired, |
(4) | (C++26 以降 constexpr) |
参照されているオブジェクトの値表現をexpectedの値表現と比較し、ビット列が等しい場合は、前者を参照されているオブジェクトにdesiredで置き換えます(読み取り・変更・書き込み操作を実行します)。そうでない場合は、参照されているオブジェクトに格納されている実際の値をexpectedにロードします(ロード操作を実行します)。
これらのオーバーロードは、std::is_const_v<T>がfalseである場合にのみ、オーバーロード解決に参加します。
もしfailureがstd::memory_order_relaxed、std::memory_order_consume、std::memory_order_acquire、またはstd::memory_order_seq_cstでない場合、動作は未定義となります。
目次 |
[編集] パラメータ
| expected | - | atomic_refオブジェクトが参照するオブジェクト内に期待される値への参照 |
| desired | - | 期待通りであった場合に、参照されているオブジェクトに格納される値 |
| success | - | 比較が成功した場合の読み取り-変更-書き込み操作のメモリ同期順序 |
| failure | - | 比較が失敗した場合の読み込み操作のメモリ同期順序 |
| order | - | 両方の操作のメモリ同期順序 |
[編集] 戻り値
参照されているオブジェクトが正常に変更された場合はtrue、それ以外の場合はfalse。
[編集] 注意
比較とコピーはビット単位(std::memcmpおよびstd::memcpyに類似)であり、コンストラクタ、代入演算子、または比較演算子は使用されません。
関数の弱い形式(1,2)は、偽陽性で失敗することが許容されています。つまり、それらが等しい場合でも、*this != expectedであるかのように動作します。compare-and-exchangeがループ内にある場合、弱いバージョンは一部のプラットフォームでより良いパフォーマンスを発揮します。
弱いcompare-and-exchangeがループを必要とし、強いものがそうしない場合、value_typeのオブジェクト表現にトラップビットが含まれている可能性がある場合、または同じ値に対して複数のオブジェクト表現を提供する(例:浮動小数点NaN)場合を除き、強いものが好ましいです。これらの場合、弱いcompare-and-exchangeは通常、安定したオブジェクト表現にすぐに収束するため機能します。
一部のメンバーの値表現には参加するが、他のメンバーの値表現には参加しないビットを持つ共用体の場合、比較交換は常に失敗する可能性があります。これは、アクティブなメンバーの値表現に参加しない場合、そのようなパディングビットには不定な値が含まれるためです。
オブジェクトの値表現に決して参加しないパディングビットは無視されます。
[編集] 欠陥報告
以下の動作変更を伴う欠陥報告が、以前に公開されたC++標準に遡って適用されました。
| DR | 適用対象 | 公開された動作 | 正しい動作 |
|---|---|---|---|
| LWG 3508 (P3323R1) |
C++20 | compare_exchange_weakおよびcompare_exchange_strongはconst Tにとっては無意味でした。 |
非 const T のみを受け入れるように制約されました。 |
[編集] 例
| このセクションは未完成です 理由: 例がありません |