名前空間
変種
操作

std::conditional

提供: cppreference.com
< cpp‎ | types
 
 
 
型サポート
型プロトタイプ
(C++11)
(C++11)
(C++14)
(C++11)
(C++11)(C++20以前)
(C++11)(C++20で非推奨)
(C++11)
型特性定数
メタ関数
(C++17)
エンディアン
(C++20)
サポートされている操作
関係と性質の問い合わせ
(C++11)
(C++11)
型変更
(C++11)(C++11)(C++11)
型変換
(C++11)
(C++11)
(C++17)
conditional
(C++11)
(C++11)(C++20以前)(C++17)
 
ヘッダ <type_traits> で定義
template< bool B, class T, class F >
struct conditional;
(C++11およびそれ以降)

コンパイル時に Btrue であれば T として、 Bfalse であれば F として定義されるメンバ型 type を提供します。

目次

[編集] メンバ型

メンバ型 定義
type B == true であれば TB == false であれば F

[編集] ヘルパー型

template< bool B, class T, class F >
using conditional_t = typename conditional<B,T,F>::type;
(C++14およびそれ以降)

[編集] 実装例

template<bool B, class T, class F>
struct conditional { typedef T type; };
 
template<class T, class F>
struct conditional<false, T, F> { typedef F type; };

[編集]

#include <iostream>
#include <type_traits>
#include <typeinfo>
 
int main() 
{
    typedef std::conditional<true, int, double>::type Type1;
    typedef std::conditional<false, int, double>::type Type2;
    typedef std::conditional<sizeof(int) >= sizeof(double), int, double>::type Type3;
 
    std::cout << typeid(Type1).name() << '\n';
    std::cout << typeid(Type2).name() << '\n';
    std::cout << typeid(Type3).name() << '\n';
}

出力例:

int
double
double

[編集] 関連項目

(C++11)
コンパイル時ブーリアンに基づいて関数オーバーロードまたはテンプレート特殊化を隠蔽します
(クラステンプレート) [edit]