共用方式為


如何:在 C++/CLI 中定義和使用列舉

C++/CLI 中的列舉類型與標準 C++ 中的列舉類型有一些差異。 本文說明如何使用 C++/CLI 列舉類型,以及如何與標準列舉類型交互操作。

指定 enum 的基礎類型

根據預設,列舉的基礎類型是 int。 不過,您可以指定 intshortlong__int32__int64 的已簽署或未簽署形式類型。 您也可以使用 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);
}

輸出

sun
0
1
2

如何在受控和標準列舉間轉換

列舉與整數類型之間沒有標準轉換;需要轉換。

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

輸出

a and day2 are the same

運算子和列舉

下列運算子在 C++/CLI 中的列舉上有效:

運算子
== != < > <= >=
+ -
| ^ & ~
++ --
sizeof

運算子 |^&~++-- 只會針對具有整數基礎類型的列舉定義,不包括 bool。 兩個運算元都必須是列舉類型。

編譯器不會對列舉作業的結果進行靜態或動態檢查;作業可能會導致值不在列舉的有效列舉值範圍內。

注意

C++11 在非受控程式碼中引進 enum class 類型,這與 C++/CLI 中的受控 enum class 類型明顯不同。 特別是,C++11 enum class 類型不支援與 C++/CLI 中 受控 enum class 類型相同的運算子,而且 C++/CLI 原始程式碼必須在受控 enum class 宣告中提供協助工具規範,以便區別它們與非受控 (C++11) enum class 宣告。 如需在 C++/CLI、C++/CX 和 C++11 中使用 enum class 的詳細資訊,請參閱 enum class

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

使用範圍限定詞來區分 enumenum class 值:

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

輸出

4
1
True

另請參閱

enum class