Namespaces
Variants

std:: is_pod

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* )
is_pod
(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_pod ;
(depuis C++11)
(obsolète en C++20)

std::is_pod est un UnaryTypeTrait .

Si T est un POD type ("plain old data 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_pod ou std::is_pod_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_pod_v = is_pod < T > :: value ;
(depuis C++17)
(obsolète en C++20)

Hérité de std:: integral_constant

Constantes membres

value
[static]
true si T est un type POD, 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_pod_v<A> == true);
class B: public A { int m; };
static_assert(std::is_pod_v<B> == false);
struct C { virtual void foo(); };
static_assert(std::is_pod_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 limite inconnue
le comportement est
indéfini dans ce cas

Voir aussi

vérifie si un type est un type standard-layout
(modèle de classe)
(C++11) (obsolète en C++26)
vérifie si un type est trivial
(modèle de classe)
(C++11)
vérifie si un type est un type scalaire
(modèle de classe)

Liens externes

Pourquoi std::is_pod est-il déprécié en C++20 ? — StackOverflow