Namespaces
Variants

std:: remove_pointer

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

Proporciona el typedef miembro type que es el tipo apuntado por T , o, si T no es un puntero, entonces type es el mismo que T .

Si el programa añade especializaciones para std::remove_pointer , el comportamiento no está definido.

Contenidos

Tipos de miembros

Nombre Definición
type el tipo apuntado por T o T si no es un puntero

Tipos auxiliares

template < class T >
using remove_pointer_t = typename remove_pointer < T > :: type ;
(desde C++14)

Implementación posible

template<class T> struct remove_pointer { typedef T type; };
template<class T> struct remove_pointer<T*> { typedef T type; };
template<class T> struct remove_pointer<T* const> { typedef T type; };
template<class T> struct remove_pointer<T* volatile> { typedef T type; };
template<class T> struct remove_pointer<T* const volatile> { typedef T type; };
**Nota:** El contenido dentro de las etiquetas `
` contiene código C++ que no debe ser traducido según las instrucciones proporcionadas. El texto circundante (como los nombres de clases CSS y atributos HTML) se ha mantenido sin cambios para preservar el formato original.

Ejemplo

#include <type_traits>
static_assert
(
    std::is_same_v<int, int> == true &&
    std::is_same_v<int, int*> == false &&
    std::is_same_v<int, int**> == false &&
    std::is_same_v<int, std::remove_pointer_t<int>> == true &&
    std::is_same_v<int, std::remove_pointer_t<int*>> == true &&
    std::is_same_v<int, std::remove_pointer_t<int**>> == false &&
    std::is_same_v<int, std::remove_pointer_t<int* const>> == true &&
    std::is_same_v<int, std::remove_pointer_t<int* volatile>> == true &&
    std::is_same_v<int, std::remove_pointer_t<int* const volatile>> == true
);
int main() {}

Véase también

(C++11)
comprueba si un tipo es un tipo puntero
(plantilla de clase)
añade un puntero al tipo dado
(plantilla de clase)