std::is_compound
Материал из cppreference.com
<tbody>
</tbody>
| Определено в заголовочном файле <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 | — | тип для проверки |
Шаблон вспомогательной переменной
<tbody> </tbody> template< class T > inline constexpr bool 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>);
enum struct 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) |
проверяет, является ли тип типом массива (шаблон класса) |