名前空間
変種
操作

std::is_swappable_with, std::is_swappable, std::is_nothrow_swappable_with, std::is_nothrow_swappable

From cppreference.com
< cpp‎ | types
 
 
メタプログラミングライブラリ
型特性
型のカテゴリ
(C++11)
(C++11)(DR*)
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
(C++11) 
(C++11)
(C++11)
型のプロパティ
(C++11)
(C++11)
(C++14)
(C++11)(C++26で非推奨)
(C++11)(C++20まで*)
(C++11)(C++20で非推奨)
(C++11)
型特性定数
メタ関数
(C++17)
サポートされている操作
is_swappable_withis_swappableis_nothrow_swappable_withis_nothrow_swappable
(C++17)(C++17)(C++17)(C++17)

関係とプロパティクエリ
型の変更
(C++11)(C++11)(C++11)
型の変換
(C++11)(C++23で非推奨)
(C++11)(C++23で非推奨)
(C++11)
(C++11)(C++20まで*)(C++17)

(C++11)
(C++17)
コンパイル時有理数演算
コンパイル時整数シーケンス
 
ヘッダ <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 を参照)、メンバ定数 valuetrue となる。そうでない場合、valuefalse となる。
アクセスチェックは、どちらの型とも関連のないコンテキストから行われるかのように実行されます。
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 =

    is_nothrow_swappable_with<T, U>::value;
(C++17以降)
template< class T >

inline constexpr bool is_nothrow_swappable_v =

    is_nothrow_swappable<T>::value;
(C++17以降)

std::integral_constant から継承

メンバ定数

value
[static]
TU とスワップ可能であれば 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つのオブジェクトの値を交換する
(関数テンプレート) [編集]
型がムーブ代入演算子を持つかをチェックする
(クラステンプレート) [編集]
型が交換可能であること、または2つの型が互いに交換可能であることを規定する
(コンセプト) [編集]
English 日本語 中文(简体) 中文(繁體)