Partilhar via


Classe enum (C++/CLI e C++/CX)

Declara uma enumeração no escopo do namespace, que é um tipo definido pelo usuário que consiste em um conjunto de constantes nomeadas chamadas de enumeradores.

Todos os Runtimes

Comentários

C++/CX e C++/CLI são compatíveis com a public enum class e à private enum class que são semelhantes ao padrão C++ enum class, mas com a adição do especificador de acessibilidade. No /clr, o tipo enum class C++11 é permitido, mas vai gerar o aviso C4472, que se destina a garantir que você realmente deseja o tipo enum ISO e não o tipo C++/CX e C++/CLI. Para mais informações sobre a palavra-chave enum C++ padrão ISO, confira Enumerações.

Windows Runtime

Sintaxe

      access
      enum class
      enumeration-identifier
      [:underlying-type] { enumerator-list } [var];
accessenum structenumeration-identifier[:underlying-type] { enumerator-list } [var];

Parâmetros

access
A acessibilidade da enumeração, que pode ser public ou private.

enumeration-identifier
O nome da enumeração.

underlying-type
(Opcional) O tipo subjacente da enumeração.

(Opcional, somente Windows Runtime ) O tipo subjacente da enumeração, que pode ser bool, char, char16, int16, uint16, int, uint32, int64 ou uint64.

enumerator-list
Uma lista de nomes de enumeradores delimitada por vírgulas.

O valor de cada enumerador é uma expressão constante que é definida implicitamente pelo compilador ou explicitamente pela notação, enumerator=constant-expression. Por padrão, o valor do primeiro enumerador é zero se estiver implicitamente definido. O valor de cada enumerador implicitamente definido subsequente é o valor do enumerador anterior + 1.

var
(Opcional) O nome de uma variável do tipo de enumeração.

Comentários

Saiba mais e obtenha exemplos em Enumerações.

Observe que o compilador emite mensagens de erro se a expressão constante que define o valor de um enumerador não puder ser representada por underlying-type. No entanto, o compilador não relata um erro para um valor que é inadequado para o tipo subjacente. Por exemplo:

  • Se underlying-type for numérico e um enumerador especificar o valor máximo para esse tipo, o valor da próxima enumeração implicitamente definida não poderá ser representado.

  • Se underlying-type for bool, e mais de dois enumeradores estiverem implicitamente definidos, os enumeradores após os dois primeiros não poderão ser representados.

  • Se underlying-type for char16, e o valor de enumeração variar de 0xD800 a 0xDFFF, o valor poderá ser representado. No entanto, o valor estará logicamente incorreto, pois representa metade de um par alternativo Unicode e não deve aparecer no isolamento.

Requisitos

Opção do compilador: /ZW

Common Language Runtime

Sintaxe

      access
      enum class
      name [:type] { enumerator-list } var;
accessenum structname [:type] { enumerator-list } var;

Parâmetros

access
A acessibilidade do enum. Pode ser public ou private.

enumerator-list
Uma lista delimitada por vírgulas dos identificadores (enumeradores) na enumeração.

name
O nome da enumeração. Enumerações gerenciadas anônimas não são permitidas.

tipo
(Opcional) O tipo subjacente dos identifiers. Pode ser qualquer tipo escalar, como versões com ou sem sinal de int, short ou long. bool ou char também é permitido.

var
(Opcional) O nome de uma variável do tipo de enumeração.

Comentários

enum class e enum struct são declarações equivalentes.

Existem dois tipos de enumerações: gerenciada ou C++/CX e standard.

Uma enumeração gerenciada ou C++/CX pode ser definida da seguinte maneira,

public enum class day {sun, mon };

e é semanticamente equivalente a:

ref class day {
public:
   static const int sun = 0;
   static const int mon = 1;
};

Uma enumeração padrão pode ser definida da seguinte maneira:

enum day2 { sun, mon };

e é semanticamente equivalente a:

static const int sun = 0;
static const int mon = 1;

Nomes de enumeradores gerenciados (identifiers) não são injetados no escopo em que a enumeração está definida; todas as referências aos enumeradores devem ser totalmente qualificadas (name::identifier). Por essa razão, não é possível definir uma enumeração gerenciada anônima.

Os enumeradores de uma enumeração padrão são fortemente injetados no escopo de inclusão. Ou seja, se há outro símbolo com o mesmo nome que um enumerador no escopo delimitador, o compilador gera um erro.

No Visual Studio 2002 e Visual Studio 2003, os enumeradores foram injetados fracamente (visíveis no escopo delimitador, a menos que houvesse outro identificador com o mesmo nome).

Se uma enumeração C++ padrão for definida (sem class ou struct), compilar com /clr fará com que a enumeração seja compilada como uma enumeração gerenciada. A enumeração ainda tem a semântica de uma enumeração não gerenciada. Note que o compilador injeta um atributo Microsoft::VisualC::NativeEnumAttribute para identificar a intenção de um programador de que a enumeração seja uma enumeração nativa. Outros compiladores simplesmente veem a enumeração padrão como uma enumeração gerenciada.

Uma enumeração padrão nomeada compilada com /clr fica visível no assembly como uma enumeração gerenciada e pode ser consumida por qualquer outro compilador gerenciado. No entanto, uma enumeração padrão sem nome não fica visível publicamente a partir do assembly.

No Visual Studio 2002 e Visual Studio 2003, uma enumeração padrão usada como o tipo em um parâmetro de função:

// mcppv2_enum.cpp
// compile with: /clr
enum E { a, b };
void f(E) {System::Console::WriteLine("hi");}

int main() {
   E myi = b;
   f(myi);
}

emitiria o seguinte no MSIL para a assinatura da função:

void f(int32);

No entanto, nas versões atuais do compilador, a enumeração padrão é emitida como uma enumeração gerenciada com um [NativeEnumAttribute] e o seguinte no MSIL para a assinatura da função:

void f(E)

Saiba mais sobre enumerações nativas em Declarações de enumeração do C++.

Saiba mais sobre enumerações do CLR em:

Requisitos

Opção do compilador: /clr

Exemplos

// mcppv2_enum_2.cpp
// compile with: /clr
// managed enum
public enum class m { a, b };

// standard enum
public enum n { c, d };

// unnamed, standard enum
public enum { e, f } o;

int main()
{
   // consume managed enum
   m mym = m::b;
   System::Console::WriteLine("no automatic conversion to int: {0}", mym);
   System::Console::WriteLine("convert to int: {0}", (int)mym);

   // consume standard enum
   n myn = d;
   System::Console::WriteLine(myn);

   // consume standard, unnamed enum
   o = f;
   System::Console::WriteLine(o);
}
no automatic conversion to int: b

convert to int: 1

1

1

Confira também

Extensões de componentes para .NET e UWP