名前空間
変種
操作

std::atomic_ref<T>::fetch_sub

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で非推奨)
アトミック操作のためのフリー関数
アトミックフラグのためのフリー関数
 
 
Tcv bool以外の算術型またはオブジェクトへのポインタ型の場合にのみ提供される
value_type fetch_sub( difference_type arg,

                      std::memory_order order =

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

参照されているオブジェクトの現在の値を、値とargの算術減算の結果でアトミックに置き換えます。この操作は読み取り-変更-書き込み操作です。メモリはorderの値に応じて影響を受けます。

  • 符号付き整数型の場合、算術演算は2の補数表現を使用するように定義されています。未定義の結果はありません。
  • 浮動小数点型の場合、有効な浮動小数点環境は、呼び出しスレッドの浮動小数点環境とは異なる場合があります。この操作は、対応するstd::numeric_limitsの特性に準拠する必要はありませんが、準拠することが推奨されます。結果がその型の表現可能な値でない場合、結果は未指定ですが、操作自体に未定義の動作はありません。
  • ポインタ型の場合、結果は未定義のアドレスになる可能性がありますが、操作自体に未定義の動作はありません。
    • std::remove_pointer_t<T>が完全なオブジェクト型でない場合、プログラムは不正形式です。

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

目次

[編集] パラメータ

arg - 算術減算のもう一方の引数
order - 強制するメモリ順序制約

[編集] 戻り値

この関数の効果が及ぼす直前の、*ptrによって参照される値。

[編集]

[編集] 不具合報告

以下の動作変更を伴う欠陥報告が、以前に公開されたC++標準に遡って適用されました。

DR 適用対象 公開された動作 正しい動作
LWG 3508
(P3323R1)
C++20 fetch_subconst Tに対して無意味でした。 非 const T のみを受け入れるように制約されました。
English 日本語 中文(简体) 中文(繁體)