列舉是開發者可以定義的乙個型別。列舉的關鍵特徵是它標識了乙個在編譯時定義的所有可能值得集合,每個值都由乙個名稱來引用,這就使得**更加的易讀。我們採用與類相似的語法來定義乙個列舉(列舉型別的宣告必須跟類是平級的),如:
enum connectionstate
布林型別的引數也適合使用列舉。例如:像setstate(devicestate.on)這樣的方法呼叫要比setstate(true)更易讀。
要引用乙個列舉值,需要為其附加列舉名稱字首。例如,要引用connected的值,需要使用connectionstate.connected。在列舉值名稱中,不允許使用列舉名稱,根據約定,列舉名稱本身應該使用單數形式,除非列舉是為標誌。
預設情況下,第乙個列舉值是0(技術上說,是0顯式轉型為基礎列舉型別),後續每一項都遞增1,然而可以顯式的為列舉賦值,**如下:
//顯式的為列舉值賦值enum connectionstate : short
disconnected任然具有預設值0,connection被賦值為10,後面connected的值為11,隨後joined也被賦值為11也就是有connected引用的值(將connected引用的值賦給joined時,不需要為connected附加列舉名稱字首,因為目前正處在列舉的作用域內)。disconnecting自動遞增1,值為12.
列舉總是具有乙個基礎型別,這可能是int,uint,long和ulong,但不能使char。
事實上,列舉型別的效能完全取決於基礎型別的效能。預設的基礎型別為int,但是可以使用繼承的語法來指定乙個不同的型別。
在上面的**中,使用的是short,而不是int。為了保持一致性,這裡使用了繼承的語法,但沒有建立真正的繼承關係。
c#不支援兩個不同的列舉陣列之間的直接轉型。但是可以使用強制的轉換,就是先轉型為乙個陣列,在轉型為第二個列舉。這裡要求兩個列舉具有相同的基礎型別,而且必須先轉型為system.array,**如下:
static void main(string args)
//列舉陣列之間的轉型enum connectionstate1
enum connectionstate2
這個技巧利用了clr的賦值相容性比c#寬鬆這一事實。(還可以同樣的技巧進行非法轉換,比如int轉換為uint)。然而,使用時必須謹慎,c#規範沒有說不同的clr實現中,這個技巧都應該正常的發揮作用。
C 列舉型別解析
列舉是開發者可以定義的乙個型別。列舉的關鍵特徵是它標識了乙個在編譯時定義的所有可能值得集合,每個值都由乙個名稱來引用,這就使得 更加的易讀。我們採用與類相似的語法來定義乙個列舉 列舉型別的宣告必須跟類是平級的 如 enum connectionstate 布林型別的引數也適合使用列舉。例如 像set...
C語言 enum列舉型別用法解析
在實際的程式設計應用中,有的變數只有幾種可能的取值,譬如說乙個星期的七種可能,性別的兩種可能等等。c語言為這種型別的變數的定義提供了enum關鍵字。要使用列舉型別的變數,首先需要先定義乙個列舉型別名,然後再宣告該變數是列舉型別的 enum weekday enum weekday day 該語句宣告...
C 列舉型別
c 中的列舉型別繼承於 c 語言。就像其他從 c 語言繼承過來的很多特性一樣,c 列舉也有缺點,這其中最顯著的莫過於作用域問題 在列舉型別中定義的常量,屬於定義列舉的作用域,而不屬於這個列舉型別。例如下面的示例 enum fileaccess fileaccess access read 正確 fi...