Classe is_pod
Verificare se il tipo è POD.
template<class Ty>
struct is_pod;
Parametri
- Ty
Il tipo da eseguire la query.
Note
is_pod<Ty>::value è true se il tipo è Ty dati non aggiornati normali (POD). In caso contrario è false.
I tipi, tipi di enumerazione, i tipi di puntatore e il puntatore all'aritmetica ai tipi di membri sono POD.
Una versione cv- qualificata di un tipo POD stessa è un tipo POD.
Una matrice POD è lo stesso MOMENTO.
Una struttura o un'unione, tutti i cui membri dati non statici sono MOMENTO, è stesso MOMENTO se sono:
Nessun costruttori utente dichiarate.
Membri dati non statici non private o protected.
Nessuna classe base.
Nessun funzioni virtuali.
Nessun membri dati non statici di tipo riferimento.
Alcun operatore di assegnazione di copia definito dall'utente.
Nessun distruttore definito dall'utente.
Pertanto, è possibile in modo ricorsivo compilare strutture e le matrici POD che contengono strutture e le matrici POD.
Esempio
// std_tr1__type_traits__is_pod.cpp
// compile with: /EHsc
#include <type_traits>
#include <iostream>
struct trivial
{
int val;
};
struct throws
{
throws() throw(int)
{
}
throws(const throws&) throw(int)
{
}
throws& operator=(const throws&) throw(int)
{
}
int val;
};
int main()
{
std::cout << "is_pod<trivial> == " << std::boolalpha
<< std::is_pod<trivial>::value << std::endl;
std::cout << "is_pod<int> == " << std::boolalpha
<< std::is_pod<int>::value << std::endl;
std::cout << "is_pod<throws> == " << std::boolalpha
<< std::is_pod<throws>::value << std::endl;
return (0);
}
Requisiti
Intestazione: <type_traits>
Spazio dei nomi: std