Partilhar via


is_pod Class

Se o tipo é o POD de testes.

template<class Ty>
    struct is_pod;

Parâmetros

  • Ty
    O tipo de consulta.

Comentários

is_pod<Ty>::valueé true se o tipo de Ty é a Data antiga comum (POD).Caso contrário é false.

Tipos de aritméticos, tipos de enumeração, tipos de ponteiro e ponteiro para tipos de membro são POD.

Uma versão VC qualificado de um tipo POD é um tipo POD.

Uma matriz de POD é POD.

Uma struct ou união, todos os membros cujos dados não-static são POD, é próprio POD se ele tiver:

  • Nenhum construtor declarado por usuário.

  • Nenhum membro de dados de não-static particular ou protegido.

  • Não há classes base.

  • Não há funções virtuais.

  • Nenhum membro de dados não-estático do tipo de referência.

  • Nenhum operador de atribuição de cópia definido pelo usuário.

  • Nenhum destruidor definidos pelo usuário.

Portanto, você pode recursivamente structs POD de compilação e matrizes que contêm matrizes e estruturas POD.

Exemplo

// 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); 
    } 
 
  

Requisitos

Cabeçalho: <type_traits>

Namespace: std

Consulte também

Referência

<type_traits>

Outros recursos

<type_traits> Membros