C# Bedingter Bediener und implizites Byteguss: Ein Typ Sicherheitstyp
Verwenden des bedingten Operators (? :
) mit implizitem Byte -Gießen kann zu Kompilierungsfehlern in C#führen. Zum Beispiel erscheint aByteValue = aBoolValue ? 1 : 0;
unkompliziert, fällt jedoch aufgrund der Inkompatibilität von Typen aus.
C#erfordert kompatible Typen in Zuordnungen. Der Typ des bedingten Operators wird durch seine wahren und falschen Ausdrücke bestimmt. Im Beispiel sind 1
und 0
Ganzzahlen, was den gesamten Ausdruck zu einer Ganzzahl macht. Das Zuweisen dieser Ganzzahl zu einer byte
Variablen (aByteValue
) ist problematisch, da ein byte
einen kleineren Bereich als ein int
hat. Der Compiler verhindert diese implizite Konvertierung, um die Art der Type aufrechtzuerhalten.
Die Lösung beinhaltet explizites Gießen: aByteValue = aBoolValue ? (byte)1 : (byte)0;
. Dies wandelt die ganzzahligen Literale ausdrücklich in Bytes um und löst den Typ -Missverhältnis.
Dieses Verhalten stammt aus dem Typ -Inferenzmechanismus von C#, wodurch die Bestimmung der Expressionstypen unabhängig von ihren Zuordnungszielen priorisiert. Dies sorgt für die Sicherheit von Typen auch bei mehreren Zuordnungszielen von unterschiedlichen Typen.
Die einzige Ausnahme von dieser Regel ist mit Lambda-Ausdrücken, bei denen der kontextbasierte Typ-Inferenz zur Kompatibilität mit dem umgebenden Code verwendet wird.
Das obige ist der detaillierte Inhalt vonWarum wirft C# einen Fehler, wenn der bedingte Operator mit implizitem Byte -Casting verwendet wird?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!