Condividi tramite


Procedura: definire e utilizzare enumerazioni in C++/CLI

In questo argomento vengono descritte le enumerazioni in C++/CLI.

Specificare il tipo sottostante di un'enumerazione

Per impostazione predefinita, il tipo sottostante di un'enumerazione è int.Tuttavia, è possibile specificare il tipo da firmare o form senza segno a int, di short, di long, di __int32, o di __int64.È inoltre possibile utilizzare 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);
}

Output

  

La conversione tra enumerazioni gestite e standard

Nessuna conversione standard tra un'enumerazione e un tipo integrale, un cast richiesto.

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

Output

  

Operatori e enumerazioni

I seguenti operatori sono validi sulle enumerazioni in C++/CLI:

Operatore

== != < > <= >=

+ -

| ^ ~ &

++ --

sizeof

Operatori | ^ ~ & c++ -- vengono definiti solo per le enumerazioni con i tipi sottostanti integrali, escluso il bool.Entrambi gli operandi devono avere lo stesso tipo di enumerazione.

Il compilatore non è statico o dinamico controllare il risultato di un'operazione di enumerazione, l'operazione può comportare un valore non compresi gli enumeratori validi di enumerazione.

[!NOTA]

C++11 viene presentata la classe di enumerazione nel codice non gestito che sono molto diverse delle classi gestite di enumerazione in C++/CLI.In particolare, il tipo di classe enum C++11 non supporta gli stessi operatori come classe gestita enum digitare in C++/CLI e il codice sorgente C++/CLI deve fornire un identificatore di accessibilità nelle dichiarazioni di classi gestite enum per distinguerle dalle dichiarazioni di classe non gestite enum (C++11).Per ulteriori informazioni su enum le classi in C++/CLI, C++/CX e C++11, vedere classe di enumerazione (Estensioni del componente 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);
}

Output

  

Vedere anche

Riferimenti

classe di enumerazione (Estensioni del componente C++)