C 列舉型別解析

2021-06-06 10:27:50 字數 1299 閱讀 3886

列舉是開發者可以定義的乙個型別。列舉的關鍵特徵是它標識了乙個在編譯時定義的所有可能值得集合,每個值都由乙個名稱來引用,這就使得**更加的易讀。我們採用與類相似的語法來定義乙個列舉(列舉型別的宣告必須跟類是平級的),如:

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...