std::is_swappable_with, std::is_swappable, std::is_nothrow_swappable_with, std::is_nothrow_swappable
From cppreference.com
| ヘッダ <type_traits> で定義 |
||
| template< class T, class U > struct is_swappable_with; |
(1) | (C++17以降) |
| template< class T > struct is_swappable; |
(2) | (C++17以降) |
| template< class T, class U > struct is_nothrow_swappable_with; |
(3) | (C++17以降) |
| template< class T > struct is_nothrow_swappable; |
(4) | (C++17以降) |
1) using std::swap; の後、swap(std::declval<T>(), std::declval<U>()) および swap(std::declval<U>(), std::declval<T>()) の両方の式が、評価されないコンテキストで整形式である場合(Swappable を参照)、メンバ定数
value は true となる。そうでない場合、value は false となる。 アクセスチェックは、どちらの型とも関連のないコンテキストから行われるかのように実行されます。
3) (1) と同じだが、(1) の両方の式の評価が例外をスローしないことが分かっている。
| 型特性 | メンバ定数 value の値 | |
|---|---|---|
T は 参照可能な型 |
T は参照可能な型ではない | |
| (2) | std::is_swappable_with<T&, T&>::value | false |
| (4) | std::is_nothrow_swappable_with<T&, T&>::value | |
T または U が不完全な型、(おそらく cv 修飾された) void、または境界が不明な配列である場合、動作は未定義です。
上記のテンプレートのインスタンス化が、直接的または間接的に不完全な型に依存し、その型が仮に完全になった場合にそのインスタンス化が異なる結果を生み出す可能性がある場合、動作は未定義です。
プログラムがこのページで説明されているテンプレートのいずれかに特殊化を追加する場合、動作は未定義です。
目次 |
[編集] ヘルパー変数テンプレート
| template< class T, class U > inline constexpr bool is_swappable_with_v = is_swappable_with<T, U>::value; |
(C++17以降) | |
| template< class T > inline constexpr bool is_swappable_v = is_swappable<T>::value; |
(C++17以降) | |
| template< class T, class U > inline constexpr bool is_nothrow_swappable_with_v = |
(C++17以降) | |
| template< class T > inline constexpr bool is_nothrow_swappable_v = |
(C++17以降) | |
std::integral_constant から継承
メンバ定数
| value [static] |
T が U とスワップ可能であれば true、そうでなければ false(公開静的メンバ定数) |
メンバ関数
| operator bool |
オブジェクトを bool に変換し、value を返します。 (public member function) |
| operator() (C++14) |
value を返します。 (public member function) |
メンバ型
| 型 | 定義 |
value_type
|
bool |
type
|
std::integral_constant<bool, value> |
[編集] 備考
この特性は、スワップ式の直接的なコンテキスト外の何もチェックしません。つまり、T または U の使用がテンプレートの特殊化、暗黙的に定義された特殊メンバ関数の生成などをトリガーし、それらにエラーがある場合、std::is_swappable_with<T, U>::value がコンパイルされて true に評価されたとしても、実際のスワップはコンパイルできない場合があります。
[編集] 例
| このセクションは未完成です 理由: 例がありません |
[編集] 関連項目
| 2つのオブジェクトの値を交換する (関数テンプレート) | |
| (C++11)(C++11)(C++11) |
型がムーブ代入演算子を持つかをチェックする (クラステンプレート) |
| (C++20) |
型が交換可能であること、または2つの型が互いに交換可能であることを規定する (コンセプト) |