Namespaces
Variants

std:: is_const

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

std::is_const es un UnaryTypeTrait .

Si T es un tipo calificado como const (es decir, const , o const volatile ), proporciona la constante miembro value igual a true . Para cualquier otro tipo, value es false .

Si el programa añade especializaciones para std::is_const o std::is_const_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_const_v = is_const < T > :: value ;
(desde C++17)

Heredado de std:: integral_constant

Constantes miembro

value
[static]
true si T es un tipo calificado como const, 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

Si T es un tipo de referencia entonces is_const < T > :: value siempre es false . La forma correcta de verificar si un tipo potencialmente referenciado es const es eliminar la referencia: is_const < typename remove_reference < T > :: type > .

Implementación posible

template<class T> struct is_const          : std::false_type {};
template<class T> struct is_const<const T> : std::true_type {};

Ejemplo

#include <type_traits>
static_assert(std::is_same_v<const int*, int const*>,
    "Recuerda, la constancia se vincula estrechamente dentro de los punteros.");
static_assert(!std::is_const_v<int>);
static_assert(std::is_const_v<const int>);
static_assert(!std::is_const_v<int*>);
static_assert(std::is_const_v<int* const>,
    "Porque el puntero en sí no puede cambiarse pero el int apuntado sí puede.");
static_assert(!std::is_const_v<const int*>,
    "Porque el puntero en sí puede cambiarse pero no el int apuntado.");
static_assert(!std::is_const_v<const int&>);
static_assert(std::is_const_v<std::remove_reference_t<const int&>>);
struct S
{
    void foo() const {}
    void bar() const {}
};
int main()
{
    // Una función miembro const es const de manera diferente:
    static_assert(!std::is_const_v<decltype(&S::foo)>,
        "Porque &S::foo es un puntero.");
    using S_mem_fun_ptr = void(S::*)() const;
    S_mem_fun_ptr sfp = &S::foo;
    sfp = &S::bar; // OK, puede ser redirigido
    static_assert(!std::is_const_v<decltype(sfp)>,
        "Porque sfp es el mismo tipo de puntero y por lo tanto puede ser redirigido.");
    const S_mem_fun_ptr csfp = &S::foo;
    // csfp = &S::bar; // Error
    static_assert(std::is_const_v<decltype(csfp)>,
        "Porque csfp no puede ser redirigido.");
}

Véase también

comprueba si un tipo está calificado como volátil
(plantilla de clase)
(C++17)
obtiene una referencia const a su argumento
(plantilla de función)