Poznámka:
Přístup k této stránce vyžaduje autorizaci. Můžete se zkusit přihlásit nebo změnit adresáře.
Přístup k této stránce vyžaduje autorizaci. Můžete zkusit změnit adresáře.
Typy výčtů v jazyce C++/CLI mají určité rozdíly s typy výčtů ve standardním jazyce C++. Tento článek vysvětluje, jak používat typy výčtů C++/CLI a jak interoperovat se standardními typy výčtů.
Určení základního typu enum
Ve výchozím nastavení je intzákladní typ výčtu . Můžete však zadat typ, který má být ve formě podepsaného nebo nepodepsaného tvaru int, short, long, __int32, nebo __int64. Můžete také použít 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);
}
Výstup
sun
0
1
2
Jak převést mezi spravovanými a standardními výčty
Mezi výčtem a celočíselným typem neexistuje žádný standardní převod; je zapotřebí přetypování.
// 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");
}
Výstup
a and day2 are the same
Operátory a výčty
Následující operátory jsou platné pro výčty v jazyce C++/CLI:
| Operátor |
|---|
==
!=
<
>
<=
>=
|
+
-
|
|
^
&
~
|
++
--
|
sizeof |
Operátory |, , ^, &~, ++a -- jsou definovány pouze pro výčty s celočíselnými podkladovými typy, které neobsahují bool. Oba operandy musí být typu výčtového.
Kompilátor neprovádí statickou ani dynamickou kontrolu výsledku operace s výčtem; operace může vést k tomu, že hodnota je mimo rozsah platných výčtových hodnot.
Poznámka:
C++11 zavádí enum class typy v nespravovaném kódu, které se výrazně liší od spravovaných enum class typů v C++/CLI. Konkrétně typ C++11 enum class nepodporuje stejné operátory jako spravovaný enum class typ v C++/CLI a zdrojový kód jazyka C++/CLI musí poskytovat specifikátor přístupnosti ve spravovaných enum class deklaracích, aby bylo možné je odlišit od nespravovaných deklarací (C++11). enum class Další informace o enum class použití v C++/CLI, C++/CX a C++11 naleznete v tématu 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
;
}
K rozlišení mezi hodnotami enum a enum class použijte kvalifikátory rozsahu.
// 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);
}
Výstup
4
1
True