Compartilhar via


Como definir e consumir enumerações em C++/CLI

Este tópico discute enum em C++/CLI.

Especificando o tipo subjacente de um enum

Por padrão, o tipo subjacente de uma enumeração é int.No entanto, você pode especificar o tipo a ser assinados ou formulários sem sinal de int, de short, de long, de __int32, ou de __int64.Você também pode usar char.

// mcppv2_enum_3.cpp
// compile with: /clr
public enum class day_char : char {sun, mon, tue, wed, thu, fri, sat};

int main() {
   // fully qualified names, enumerator not injected into scope
   day_char d = day_char::sun, e = day_char::mon;
   System::Console::WriteLine(d);
   char f = (char)d;
   System::Console::WriteLine(f);
   f = (char)e;
   System::Console::WriteLine(f);
   e = day_char::tue;
   f = (char)e;
   System::Console::WriteLine(f);
}

Saída

  

Como converter entre enumerações gerenciados e padrões

Não há nenhuma conversão padrão entre um enum e um tipo integral; uma conversão é exigida.

// mcppv2_enum_4.cpp
// compile with: /clr
enum class day {sun, mon, tue, wed, thu, fri, sat};
enum {sun, mon, tue, wed, thu, fri, sat} day2; // unnamed std enum

int main() {
   day a = day::sun;
   day2 = sun;
   if ((int)a == day2)
   // or...
   // if (a == (day)day2)
      System::Console::WriteLine("a and day2 are the same");
   else
      System::Console::WriteLine("a and day2 are not the same");
}

Saída

  

Operadores e enum

Os seguintes operadores são válidos em enum em C++/CLI:

Operator

== != < > <= >=

+ -

| ^ & ~

++ --

sizeof

Operadores | ^ & ~ ++ -- são definidos somente para enumerações com tipos integral subjacente, não incluindo o booleano.Ambos os operandos devem ser do tipo de enumeração.

O compilador não faz nenhum verificar estático ou dinâmico do resultado de uma operação enum; uma operação pode resultar em um valor não no intervalo dos enumeradores válidos enum.

ObservaçãoObservação

C++11 apresenta a classe enum no código não gerenciado que é significativamente diferente do que as classes gerenciadas enum em C++/CLI.Em particular, o tipo da classe C++11 enum não suporta os mesmos operadores que a classe gerenciada enum em C++/CLI, e o código-fonte de C++/CLI deve fornecer um especificador de acessibilidade em declarações gerenciados da classe enum para distingui-las das declarações não gerenciado de classe enum (C++11).Para obter mais informações sobre enum classes em C++/CLI, C++/CX, e C++11, consulte classe enum (Extensões de Componentes C++).

// mcppv2_enum_5.cpp
// compile with: /clr
private enum class E { a, b } e, mask;
int main() {
   if ( e & mask )   // C2451 no E->bool conversion
      ;

   if ( ( e & mask ) != 0 )   // C3063 no operator!= (E, int)
      ;

   if ( ( e & mask ) != E() )   // OK
      ;
}

// mcppv2_enum_6.cpp
// compile with: /clr
private enum class day : int {sun, mon};
enum : bool {sun = true, mon = false} day2;

int main() {
   day a = day::sun, b = day::mon;
   day2 = sun;

   System::Console::WriteLine(sizeof(a));
   System::Console::WriteLine(sizeof(day2));
   a++;
   System::Console::WriteLine(a == b);
}

Saída

  

Consulte também

Referência

classe enum (Extensões de Componentes C++)