Почему я должен приводить перечисления к int в C #?
Вопрос
Это мой код:
internal enum WindowsMessagesFlags {
WM_EXITSIZEMOVE = 0x00000232,
WM_DISPLAYCHANGE = 0x0000007e,
WM_MOVING = 0x00000216,
}
protected override void WndProc(ref Message m) {
switch(m.Msg) {
case (int)WindowsMessagesFlags.WM_DISPLAYCHANGE:
FixWindowSnapping();
break;
case (int)WindowsMessagesFlags.WM_EXITSIZEMOVE:
SaveWindowProperties();
break;
case (int)WindowsMessagesFlags.WM_MOVING:
KeepProperLocation(ref m);
break;
}
}
Есть ли способ предотвратить кастинг?
Решение
В некотором роде - вместо этого приведите m.Msg:
protected override void WndProc(ref Message m) {
switch((WindowsMessagesFlags) m.Msg) {
case WindowsMessagesFlags.WM_DISPLAYCHANGE:
FixWindowSnapping();
break;
case WindowsMessagesFlags.WM_EXITSIZEMOVE:
SaveWindowProperties();
break;
case WindowsMessagesFlags.WM_MOVING:
KeepProperLocation(ref m);
break;
}
}
Причина, по которой вы вообще нуждаетесь в приведении, состоит в том, что в C # перечисления - это не просто числа - это числа, связанные с типом. Это мешает вам делать (без приведения):
HttpStatusCode status = someWindowsMessageFlag;
Это, безусловно, хорошая вещь :) Однако, когда вам это нужно, вы всегда можете перейти к " через " базовый тип (в данном случае int).
Другие советы
Что такое Message.Msg?
Держу пари, это Int32.
Я также держу пари, что WindowsMessagesFlags - ваш тип, но Message - из фреймворка.
Это означает, что вы используете свой собственный enum со встроенным в фреймворк объектом, и, конечно, они будут иметь некоторые несовместимости в отношении типов.
Перечисление - это строгий тип, а не просто число , это число с именем в контексте . Это имя, контекст, номер, часть не совместимы напрямую только с числами, и именно поэтому вам необходимо выполнить приведение.
Одна из причин в том, что C # в настоящее время (4.0) не позволяет вам писать неявную перегрузку оператора (приведение) в методе расширения ( связанный вопрос ) для любого типа, включая перечисление. Было бы неплохо выполнить чистое преобразование в / из Int16 при интеграции со слабо типизированной базой данных, например, или со слабо типизированным форматом сериализации (двоичный модуль записи).