std::is_compound
Материал из cppreference.com
Определено в заголовочном файле <type_traits> | ||
template<class T > struct is_compound; | (начиная с C++11) | |
std::is_compound
является UnaryTypeTrait.
Если T
является составным типом (то есть массивом, функцией, указателем на объект, указателем на функцию, указателем на объект-элемент, указателем на функцию-элемент, ссылкой, классом, объединением или перечислением, включая любые cv-квалифицированные варианты) , предоставляет константу элемент value
, равную true. Для любого другого типа value
равна false.
Поведение программы, добавляющей специализации для std::is_compound
или std::is_compound_v
(начиная с C++17) не определено.
Содержание |
[править]Параметры шаблона
T | — | тип для проверки |
[править]Шаблон вспомогательной переменной
template<class T > inlineconstexprbool is_compound_v = is_compound<T>::value; | (начиная с C++17) | |
Унаследован от std::integral_constant
Константы элементы
value [static] | true, если T является составным типом, false иначе (public static константа-элемент) |
Функции-элементы
operator bool | преобразует объект в bool, возвращает value (public функция-элемент) |
operator() (C++14) | возвращает value (public функция-элемент) |
Типы элементы
Тип | Определение |
value_type | bool |
type | std::integral_constant<bool, value> |
[править]Примечание
Составные типы это типы, построенные из фундаментальных типов. Любой тип C++ является фундаментальным или составным.
[править]Возможная реализация
template<class T >struct is_compound :std::integral_constant<bool, !std::is_fundamental<T>::value>{}; |
[править]Пример
Запустить этот код
#include <type_traits> static_assert(not std::is_compound_v<int>); static_assert(std::is_compound_v<int*>); static_assert(std::is_compound_v<int&>); void f(); static_assert(std::is_compound_v<decltype(f)>); static_assert(std::is_compound_v<decltype(&f)>); static_assert(std::is_compound_v<char['a']>); class C {}; static_assert(std::is_compound_v<C>); union U {}; static_assert(std::is_compound_v<U>); enumstruct E { e }; static_assert(std::is_compound_v<E>); static_assert(std::is_compound_v<decltype(E::e)>); struct S {int i :8;int j;void foo();}; static_assert(not std::is_compound_v<decltype(S::i)>); static_assert(not std::is_compound_v<decltype(S::j)>); static_assert(std::is_compound_v<decltype(&S::j)>); static_assert(std::is_compound_v<decltype(&S::foo)>); int main(){}
[править]Смотрите также
(C++11) | проверяет, является ли тип фундаментальным типом (шаблон класса) |
(C++11) | проверяет, является ли тип целочисленным типом (шаблон класса) |
(C++11) | проверяет, является ли тип объектным типом (шаблон класса) |
(C++11) | проверяет, является ли тип типом массива (шаблон класса) |