Observação
O acesso a essa página exige autorização. Você pode tentar entrar ou alterar diretórios.
O acesso a essa página exige autorização. Você pode tentar alterar os diretórios.
Os tipos de enumeração na C++/CLI têm algumas diferenças com os tipos de enumeração no C++padrão. Este artigo explica como usar tipos de enumeração C++/CLI e como interoperar com tipos de enumeração padrão.
Especificando o tipo subjacente de um enum
Por padrão, o tipo subjacente de uma enumeração é int. No entanto, você pode especificar o tipo a ser assinado ou sem sinal de int, , longshort, __int32ou __int64. Também é possível usar 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);
}
Saída
sun
0
1
2
Como converter entre enumerações gerenciadas e padrão
Não há conversão padrão entre uma enumeração e um tipo integral; uma conversão é necessária.
// 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");
}
Saída
a and day2 are the same
Operadores e enumerações
Os seguintes operadores são válidos em enumerações na C++/CLI:
| Operador |
|---|
==
!=
<
>
<=
>=
|
+
-
|
|
^
&
~
|
++
--
|
sizeof |
Operadores |, ^, &, , ~, ++e -- são definidos apenas para enumerações com tipos subjacentes integrais, não incluindo bool. Ambos os operandos devem ser do tipo de enumeração.
O compilador não faz nenhuma verificação estática ou dinâmica do resultado de uma operação de enumeração; uma operação pode resultar em um valor que não está no intervalo dos enumeradores válidos da enumeração.
Observação
O C++11 introduz enum class tipos em código não gerenciado, que são significativamente diferentes dos tipos gerenciados enum class na C++/CLI. Em particular, o tipo C++11 enum class não dá suporte aos mesmos operadores que o tipo gerenciado enum class na C++/CLI e o código-fonte C++/CLI deve fornecer um especificador de acessibilidade em declarações gerenciadas enum class para distingui-los de declarações não gerenciadas (C++11 enum class ). Para obter mais informações sobre enum class o uso em C++/CLI, C++/CX e C++11, consulte 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
;
}
Use qualificadores de escopo para distinguir entre valores e enum class entreenum:
// 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);
}
Saída
4
1
True