Namespaces
Variants

std:: is_compound

From cppreference.net
Metaprogramming library
Type traits
Type categories
(C++11)
(C++11) ( DR* )
(C++11)
(C++11)
is_compound
(C++11)
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)

Compile-time rational arithmetic
Compile-time integer sequences
Definido en el encabezado <type_traits>
template < class T >
struct is_compound ;
(desde C++11)

std::is_compound es un UnaryTypeTrait .

Si T es un tipo compuesto (es decir, array, función, puntero a objeto, puntero a función, puntero a miembro de objeto, puntero a miembro de función, referencia, clase, unión o enumeración, incluyendo cualquier variante calificada cv), proporciona la constante miembro value igual a true . Para cualquier otro tipo, value es false .

Si el programa añade especializaciones para std::is_compound o std::is_compound_v , el comportamiento es indefinido.

Contenidos

Parámetros de plantilla

T - un tipo a verificar

Plantilla de variable auxiliar

template < class T >
constexpr bool is_compound_v = is_compound < T > :: value ;
(desde C++17)

Heredado de std:: integral_constant

Constantes miembro

value
[static]
true si T es un tipo compuesto, false en caso contrario
(constante miembro pública estática)

Funciones miembro

operator bool
convierte el objeto a bool , devuelve value
(función miembro pública)
operator()
(C++14)
devuelve value
(función miembro pública)

Tipos miembro

Tipo Definición
value_type bool
type std:: integral_constant < bool , value >

Notas

Los tipos compuestos son los tipos que se construyen a partir de tipos fundamentales. Cualquier tipo de C++ es fundamental o compuesto.

Implementación posible

template<class T>
struct is_compound : std::integral_constant<bool, !std::is_fundamental<T>::value> {};

Ejemplo

#include <type_traits>
#include <iostream>
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[100]>);
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()
{
    std::cout << "All checks have passed\n";
}

Véase también

verifica si un tipo es un tipo fundamental
(class template)
(C++11)
verifica si un tipo es un tipo escalar
(class template)
(C++11)
verifica si un tipo es un tipo objeto
(class template)
(C++11)
verifica si un tipo es un tipo arreglo
(class template)