Namespaces
Variants

std:: conditional

From cppreference.net
Metaprogramming library
Type traits
Type categories
(C++11)
(C++11) ( DR* )
Type properties
(C++11)
(C++11)
(C++14)
(C++11) (deprecated in C++26)
(C++11) ( until C++20* )
(C++11) (deprecated in C++20)
(C++11)
Type trait constants
Metafunctions
(C++17)
Supported operations
Relationships and property queries
Type modifications
Type transformations
(C++11) (deprecated in C++23)
(C++11) (deprecated in C++23)
(C++11)
(C++11) ( until C++20* ) (C++17)

conditional
(C++11)
(C++11)
(C++17)
Compile-time rational arithmetic
Compile-time integer sequences
Definiert im Header <type_traits>
template < bool B, class T, class F >
struct conditional ;
(seit C++11)

Bietet den Member-Typedef type , der als T definiert ist, falls B zur Kompilierzeit true ist, oder als F , falls B zur Kompilierzeit false ist.

Wenn das Programm Spezialisierungen für std::conditional hinzufügt, ist das Verhalten undefiniert.

Inhaltsverzeichnis

Mitgliedertypen

Mitgliedertyp Definition
type T falls B == true , F falls B == false

Hilfstypen

template < bool B, class T, class F >
using conditional_t = typename conditional < B,T,F > :: type ;
(seit C++14)

Mögliche Implementierung

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

Beispiel

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

Mögliche Ausgabe:

int
double
double

Siehe auch

(C++11)
entfernt bedingt eine Funktionsüberladung oder Template-Spezialisierung aus der Überladungsauflösung
(Klassentemplate)