名前空間
変種
操作

std::atomic_ref<T>::compare_exchange_weak, std::atomic_ref<T>::compare_exchange_strong

From cppreference.com
< cpp‎ | atomic‎ | atomic ref
 
 
並行性サポートライブラリ
スレッド
(C++11)
(C++20)
this_thread 名前空間
(C++11)
(C++11)
(C++11)
協調的なキャンセル
排他制御
(C++11)
汎用ロック管理
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
条件変数
(C++11)
セマフォ
ラッチとバリア
(C++20)
(C++20)
future
(C++11)
(C++11)
(C++11)
(C++11)
安全なメモリ解放 (Safe Reclamation)
(C++26)
ハザードポインタ
アトミック型
(C++11)
(C++20)
アトミック型の初期化
(C++11)(C++20で非推奨)
(C++11)(C++20で非推奨)
メモリオーダー
(C++11)(C++26で非推奨)
アトミック操作のためのフリー関数
アトミックフラグのためのフリー関数
 
 
bool compare_exchange_weak

    ( value_type& expected, value_type desired,
      std::memory_order success,

      std::memory_order failure ) const noexcept;
(1) (C++26 以降 constexpr)
bool compare_exchange_weak

    ( value_type& expected, value_type desired,
      std::memory_order order =

          std::memory_order_seq_cst ) const noexcept;
(2) (C++26 以降 constexpr)
bool compare_exchange_strong

    ( value_type& expected, value_type desired,
      std::memory_order success,

      std::memory_order failure ) const noexcept;
(3) (C++26 以降 constexpr)
bool compare_exchange_strong

    ( value_type& expected, value_type desired,
      std::memory_order order =

          std::memory_order_seq_cst ) const noexcept;
(4) (C++26 以降 constexpr)

参照されているオブジェクトの値表現をexpectedの値表現と比較し、ビット列が等しい場合は、前者を参照されているオブジェクトにdesiredで置き換えます(読み取り・変更・書き込み操作を実行します)。そうでない場合は、参照されているオブジェクトに格納されている実際の値をexpectedにロードします(ロード操作を実行します)。

1,3) 読み取り・変更・書き込み操作とロード操作のメモリモデルは、それぞれsuccessfailureです。
2,4) orderは、読み取り・変更・書き込み操作とロード操作の両方に使用されます。ただし、orderstd::memory_order_acq_relまたはstd::memory_order_releaseの場合、ロード操作にはそれぞれstd::memory_order_acquireまたはstd::memory_order_relaxedが使用されます。

これらのオーバーロードは、std::is_const_v<T>falseである場合にのみ、オーバーロード解決に参加します。

もしfailurestd::memory_order_relaxedstd::memory_order_consumestd::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 のみを受け入れるように制約されました。

[編集]

English 日本語 中文(简体) 中文(繁體)