Заметка
Доступ к этой странице требует авторизации. Вы можете попробовать войти в систему или изменить каталог.
Доступ к этой странице требует авторизации. Вы можете попробовать сменить директорию.
Типы перечисления в C++/CLI имеют некоторые различия с типами перечислений в стандартном C++. В этой статье объясняется, как использовать типы перечислений C++/CLI и как взаимодействовать со стандартными типами перечисления.
Указание базового типа объекта enum
По умолчанию базовым типом перечисления является int. Однако можно указать тип в виде подписанной или неподписанной формы для int, short, long, __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 типы в неуправляемом коде, которые значительно отличаются от управляемых enum class типов в C++/CLI. В частности, тип C++11 enum class не поддерживает те же операторы, что и управляемый тип в C++/CLI, и в исходном коде C++/CLI необходимо указать спецификатор доступности в управляемых enum class объявлениях, чтобы отличить их от неуправляемых (C++11) enum class объявлений. Дополнительные сведения об использовании enum class в C++/CLI, C++/CX и C++11 см. в разделе 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
;
}
Используйте квалификаторы области для различения enum и enum 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