std:: is_null_pointer
|
Definido en el encabezado
<type_traits>
|
||
|
template
<
class
T
>
struct is_null_pointer ; |
(desde C++11) | |
std::is_null_pointer
es un
UnaryTypeTrait
.
Comprueba si
T
es el tipo
std::nullptr_t
.
Proporciona la constante miembro
value
que es igual a
true
, si
T
es el tipo
std::nullptr_t
,
const
std::
nullptr_t
,
volatile
std::
nullptr_t
, o
const
volatile
std::
nullptr_t
.
De lo contrario, value es igual a false .
Si el programa añade especializaciones para
std::is_null_pointer
o
std::is_null_pointer_v
(desde C++17)
, el comportamiento es indefinido.
Contenidos |
Parámetros de plantilla
| T | - | un tipo a verificar |
Plantilla de variable auxiliar
|
template
<
class
T
>
constexpr bool is_null_pointer_v = is_null_pointer < T > :: value ; |
(desde C++17) | |
Heredado de std:: integral_constant
Constantes miembro
|
value
[static]
|
true
si
T
es el tipo
std::nullptr_t
(posiblemente calificado con cv),
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 > |
Implementación posible
template<class T> struct is_null_pointer : std::is_same<std::nullptr_t, std::remove_cv_t<T>> {}; |
Notas
std::is_pointer es false para std::nullptr_t porque no es un tipo de puntero incorporado.
En libc++,
std::is_null_pointer
no está disponible en modo C++11.
| Macro de prueba de características | Valor | Estándar | Característica |
|---|---|---|---|
__cpp_lib_is_null_pointer
|
201309L
|
(C++14)
(DR11) |
std::is_null_pointer
|
Ejemplo
#include <type_traits> static_assert(std::is_null_pointer_v<decltype(nullptr)>); static_assert(!std::is_null_pointer_v<int*>); static_assert(!std::is_pointer_v<decltype(nullptr)>); static_assert(std::is_pointer_v<int*>); int main() { }
Informes de defectos
Los siguientes informes de defectos que modifican el comportamiento se aplicaron retroactivamente a los estándares publicados anteriormente de C++.
| DR | Aplicado a | Comportamiento publicado | Comportamiento correcto |
|---|---|---|---|
| LWG 2247 | C++11 | faltaba el trait de tipo para detectar std::nullptr_t | añadido |
Véase también
|
(C++11)
|
comprueba si un tipo es
void
(plantilla de clase) |
|
(C++11)
|
comprueba si un tipo es un tipo arreglo
(plantilla de clase) |
|
(C++11)
|
comprueba si un tipo es un tipo puntero
(plantilla de clase) |
|
(C++11)
|
comprueba si un tipo es un tipo enumeración
(plantilla de clase) |
|
(C++11)
|
comprueba si un tipo es un tipo unión
(plantilla de clase) |
|
(C++11)
|
comprueba si un tipo es un tipo clase no unión
(plantilla de clase) |
|
(C++11)
|
comprueba si un tipo es un tipo función
(plantilla de clase) |
|
(C++11)
|
comprueba si un tipo es un tipo objeto
(plantilla de clase) |