次の方法で共有


方法: 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 の列挙型で有効です。

Operator
== != < > <= >=
+ -
| ^ & ~
++ --
sizeof

演算子 |^&~++-- は、bool を含まない、基になる型が整数である列挙型に対してのみ定義されます。 オペランドはいずれも列挙型である必要があります。

列挙型の演算の結果は、コンパイラによって静的にも動的にも確認されません。演算の結果、列挙型の有効な列挙子の範囲外の値になる可能性があります。

Note

C++11 では enum class 型がアンマネージド コードに導入されました。これは C++/CLI のマネージド enum class 型とは大幅に異なります。 特に、C++11 の enum class 型では、C++/CLI のマネージド enum class 型と同じ演算子はサポートされておらず、C++/CLI ソース コードではアンマネージド (C++11) enum class 宣言と区別するために、マネージド 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