std::is_abstract
De cppreference.com
<tbody>
</tbody>
| Definido en el archivo de encabezado <type_traits>
|
||
template< class T > struct is_abstract; |
(desde C++11) | |
std::is_abstract es un UnaryTypeTrait.
Si T es una clase abstracta (es decir, una clase que no es una unión que declara o hereda al menos una función virtual pura), proporciona la constante miembro value igual a true. Para cualquier otro tipo, value es false.
Si T es un tipo clase que no es una unión, T deberá ser un tipo completo; de lo contrario, el comportamiento está indefinido.
El comportamiento de un programa que añade especializaciones para is_abstract o is_abstract_v (desde C++17) no está definido.
Parámetros de plantilla
| T | - | Un tipo a comprobar. |
Plantilla de variable auxiliar
<tbody> </tbody> template< class T > inline constexpr bool is_abstract_v = is_abstract<T>::value; |
(desde C++17) | |
Heredado de std::integral_constant
Constantes miembro
value [estático] |
true si T es un tipo clase abstracta, de lo contrario false. (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>
|
Ejemplo
Ejecuta este código
#include <iostream>
#include <type_traits>
struct A {
int m;
};
struct B {
virtual void foo();
};
struct C {
virtual void foo() = 0;
};
struct D : C {};
int main()
{
std::cout << std::boolalpha;
std::cout << std::is_abstract<A>::value << '\n';
std::cout << std::is_abstract<B>::value << '\n';
std::cout << std::is_abstract<C>::value << '\n';
std::cout << std::is_abstract<D>::value << '\n';
}
Salida:
false
false
true
true
Véase también
(C++11) |
Comprueba si un tipo es un tipo clase (pero no un tipo unión). (plantilla de clase) |
(C++11) |
Comprueba si un tipo es tipo clase polimórfico (plantilla de clase) |