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
Défini dans l'en-tête <type_traits>
template < class T >
struct is_const ;
(depuis C++11)

std::is_const est un UnaryTypeTrait .

Si T est un type qualifié const (c'est-à-dire, const , ou const volatile ), fournit la constante membre value égale à true . Pour tout autre type, value est false .

Si le programme ajoute des spécialisations pour std::is_const ou std::is_const_v , le comportement est indéfini.

Table des matières

Paramètres du modèle

T - un type à vérifier

Modèle de variable d'assistance

template < class T >
constexpr bool is_const_v = is_const < T > :: value ;
(depuis C++17)

Hérité de std:: integral_constant

Constantes membres

value
[static]
true si T est un type qualifié const, false sinon
(constante membre publique statique)

Fonctions membres

operator bool
convertit l'objet en bool , retourne value
(fonction membre publique)
operator()
(C++14)
retourne value
(fonction membre publique)

Types membres

Type Définition
value_type bool
type std:: integral_constant < bool , value >

Notes

Si T est un type référence alors is_const < T > :: value est toujours false . La manière correcte de vérifier la constance d'un type potentiellement référence est de supprimer la référence : is_const < typename remove_reference < T > :: type > .

Implémentation possible

template<class T> struct is_const          : std::false_type {};
template<class T> struct is_const<const T> : std::true_type {};
Le code C++ dans les balises `
` a été préservé tel quel, conformément aux instructions. Aucune traduction n'a été effectuée sur le contenu à l'intérieur des balises ``, `
` ou ``, et tous les termes spécifiques au C++ ainsi que les balises HTML et attributs ont été conservés dans leur forme originale.

Exemple

#include <type_traits>
static_assert(std::is_same_v<const int*, int const*>,
    "Rappelez-vous, la constance se lie étroitement à l'intérieur des pointeurs.");
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>,
    "Car le pointeur lui-même ne peut pas être modifié mais l'entier pointé peut l'être.");
static_assert(!std::is_const_v<const int*>,
    "Car le pointeur lui-même peut être modifié mais pas l'entier pointé.");
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()
{
    // Une fonction membre const est constante d'une manière différente :
    static_assert(!std::is_const_v<decltype(&S::foo)>,
        "Car &S::foo est un pointeur.");
    using S_mem_fun_ptr = void(S::*)() const;
    S_mem_fun_ptr sfp = &S::foo;
    sfp = &S::bar; // OK, peut être redirigé
    static_assert(!std::is_const_v<decltype(sfp)>,
        "Car sfp est le même type de pointeur et peut donc être redirigé.");
    const S_mem_fun_ptr csfp = &S::foo;
    // csfp = &S::bar; // Erreur
    static_assert(std::is_const_v<decltype(csfp)>,
        "Car csfp ne peut pas être redirigé.");
}

Voir aussi

vérifie si un type est qualifié volatile
(modèle de classe)
(C++17)
obtient une référence const vers son argument
(modèle de fonction)