Namespaces
Variants

std:: is_trivial

From cppreference.net
Metaprogramming library
Type traits
Type categories
(C++11)
(C++11) ( DR* )
Type properties
(C++11)
(C++11)
(C++14)
is_trivial
(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_trivial ;
(depuis C++11)
(obsolète en C++26)

std::is_trivial est un UnaryTypeTrait .

Si T est un trivial type , fournit la constante membre value égale à true . Pour tout autre type, value est false .

Si std:: remove_all_extents_t < T > est un type incomplet et n'est pas (éventuellement qualifié cv) void , le comportement est indéfini.

Si le programme ajoute des spécialisations pour std::is_trivial ou std::is_trivial_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_trivial_v = is_trivial < T > :: value ;
(depuis C++17)
(obsolète en C++26)

Hérité de std:: integral_constant

Constantes membres

value
[static]
true si T est un type trivial, 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 >

Exemple

#include <type_traits>
struct A { int m; };
static_assert(std::is_trivial_v<A> == true);
struct B { B() {} };
static_assert(std::is_trivial_v<B> == false);
// La classe suivante montre pourquoi std::is_trivial(_v) peut être un piège.
class C
{
private:
    C() = default;
};
static_assert(std::is_trivial_v<C> == true);
static_assert(std::is_trivially_default_constructible_v<C> == false);
int main() {}

Rapports de défauts

Les rapports de défauts modifiant le comportement suivants ont été appliqués rétroactivement aux normes C++ précédemment publiées.

DR Appliqué à Comportement publié Comportement correct
LWG 2015 C++11 T pouvait être un tableau de type classe
incomplet avec une limite inconnue
le comportement est
indéfini dans ce cas

Voir aussi

vérifie si un type est trivialement copiable
(modèle de classe)
vérifie si un type a un constructeur par défaut
(modèle de classe)