方法: 定義および c++ の列挙型を使用する/cli CLIHow to: Define and consume enums in C++/CLI

このトピックでは、c++ の列挙型を説明/cli CLI。This topic discusses enums in C++/CLI.

Enum の基になる型を指定します。Specifying the underlying type of an enum

列挙体の基になる型は、既定では、intします。By default, the underlying type of an enumeration is int. ただし、ある符号付きまたは符号なしの形式の種類を指定できますintshortlong__int32、または__int64します。However, you can specify the type to be signed or unsigned forms of int, short, long, __int32, or __int64. char を使用することもできます。You can also use 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

sun
0
1
2

マネージ コードと標準列挙型の間で変換する方法How to convert between managed and standard enumerations

列挙型と整数型以外の標準変換はありません。キャストが必要です。There is no standard conversion between an enum and an integral type; a cast is required.

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

a and day2 are the same

演算子と列挙型Operators and enums

次の演算子は C で列挙型で有効な/cli CLI:The following operators are valid on enums in C++/CLI:

演算子Operator
== != < > <= >=== != < > <= >=
+ -+ -
| ^ & ~| ^ & ~
++ --++ --
sizeofsizeof

演算子|^ & ~ +-ブール値を含まない型の基になる整数型と列挙型に対してのみ定義されます。Operators | ^ & ~ ++ -- are defined only for enumerations with integral underlying types, not including bool. 列挙型の両方のオペランドがあります。Both operands must be of the enumeration type.

列挙操作の結果のチェックを静的または動的なコンパイラがしません操作は、列挙型の有効な列挙子の範囲にない値があります。The compiler does no static or dynamic checking of the result of an enum operation; an operation may result in a value not in the range of the enum's valid enumerators.

注意

C++ 11 に c++ のマネージ列挙型クラスよりも大幅に異なるアンマネージ コードで列挙型のクラス型が導入されています/cli CLI。C++11 introduces enum class types in unmanaged code which are significantly different than managed enum classes in C++/CLI. 具体的には、c++ 11 enum クラス型はサポートしていませんマネージ列挙型クラスの型として同じ演算子 c++/cli CLI、および C++/cli CLI のソース コードする必要がありますマネージ列挙型では、アクセシビリティ指定子クラスを宣言するアンマネージ (C++ と区別できるようにするには11) 列挙型クラスの宣言。In particular, the C++11 enum class type does not support the same operators as the managed enum class type in C++/CLI, and C++/CLI source code must provide an accessibility specifier in managed enum class declarations in order to distinguish them from unmanaged (C++11) enum class declarations. C++ enum クラスの詳細については/cli CLI、C +/cli/CX、および c++ 11 を参照してください。列挙型クラスします。For more information about enum classes in C++/CLI, C++/CX, and C++11, see 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
      ;
}
// 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

4
1
True

関連項目See also

enum クラスenum class