Condividi tramite


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

Vedere anche

Riferimenti

<type_traits>

Altre risorse

<type_traits> membri