Namespaces
Variants

std:: is_same

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, class U >
struct is_same ;
(desde C++11)

Si T y U nombran el mismo tipo (teniendo en cuenta las calificaciones const/volatile), proporciona la constante miembro value igual a true . De lo contrario, value es false .

Se satisface la conmutatividad, es decir, para cualesquiera dos tipos T y U , is_same < T, U > :: value == true si y solo si is_same < U, T > :: value == true .

Si el programa añade especializaciones para std::is_same o std::is_same_v (desde C++17) , el comportamiento es indefinido.

Contenidos

Plantilla de variable auxiliar

template < class T, class U >
constexpr bool is_same_v = is_same < T, U > :: value ;
(desde C++17)

Heredado de std:: integral_constant

Constantes miembro

value
[static]
true si T y U son el mismo tipo, 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, class U>
struct is_same : std::false_type {};
template<class T>
struct is_same<T, T> : std::true_type {};

Ejemplo

#include <cstdint>
#include <iostream>
#include <type_traits>
#define SHOW(...) std::cout << #__VA_ARGS__ << " : " << __VA_ARGS__ << '\n'
int main()
{
    std::cout << std::boolalpha;
    // algunos hechos definidos por la implementación
    // generalmente verdadero si 'int' es de 32 bits
    SHOW( std::is_same<int, std::int32_t>::value ); // quizás verdadero
    // posiblemente verdadero si se usa el modelo de datos ILP64
    SHOW( std::is_same<int, std::int64_t>::value ); // quizás falso
    // mismas pruebas que arriba, excepto usando el formato std::is_same_v<T, U> de C++17
    SHOW( std::is_same_v<int, std::int32_t> ); // quizás verdadero
    SHOW( std::is_same_v<int, std::int64_t> ); // quizás falso
    // comparar los tipos de un par de variables
    long double num1 = 1.0;
    long double num2 = 2.0;
    static_assert( std::is_same_v<decltype(num1), decltype(num2)> == true );
    // 'float' nunca es un tipo integral
    static_assert( std::is_same<float, std::int32_t>::value == false );
    // 'int' es implícitamente 'signed'
    static_assert( std::is_same_v<int, int> == true );
    static_assert( std::is_same_v<int, unsigned int> == false );
    static_assert( std::is_same_v<int, signed int> == true );
    // a diferencia de otros tipos, 'char' no es ni 'unsigned' ni 'signed'
    static_assert( std::is_same_v<char, char> == true );
    static_assert( std::is_same_v<char, unsigned char> == false );
    static_assert( std::is_same_v<char, signed char> == false );
    // el tipo T calificado como const no es igual a T no const
    static_assert( !std::is_same<const int, int>() );
}
#undef SHOW

Salida posible:

std::is_same<int, std::int32_t>::value : true
std::is_same<int, std::int64_t>::value : false
std::is_same_v<int, std::int32_t> : true
std::is_same_v<int, std::int64_t> : false

Véase también

(C++20)
especifica que un tipo es igual a otro tipo
(concept)
decltype especificador (C++11) obtiene el tipo de una expresión o entidad