什麼是枚舉
枚舉(enumeration),就是一組字面(單詞),每個字面對應一個字面值。
枚舉有什麼用處
例如,需要把一年四季在程序中表示出來,可能會用0,1,2,3,分別表示一年四季中的春、夏、秋、冬。這樣不能直觀的表示出是哪個季節,另外這樣的代碼不能成為健壯的代碼。假設,我們在程序中定義了一個int類型的變量seaSon,用它來存入季節。此時,可以把超出定義四季范圍內的int類型數字賦值給seaSon.
int seaSon=5; //這行代碼是合法的,不會報錯。但是,5代表一年四季中哪個季節?
枚舉類型,就可以解決這些問題。
怎麼定義枚舉
enum Season { Spring,Summer,Fall,Winter; //Spring=0,Summer=1,Fall=2,Winter=3.默認第一個成員的字面值為0 //剩下的成員,按前面的成員字面值增加1.(第一個除外,它默認是0) } enum Season { Spring=1,Summer,Fall=4,Winter; //此時Spring=1,Summer=2,Fall=4,Winter=5; }
默認情況下,枚舉中的字面值為int類型,我們可以改為其他整數類型。例如:short,byte,sbyte,ushort,int,uint,long,ulong.
enum Season: short{Spring,Summer,Fall,Winter} //將字面值改為short類型
怎樣使用枚舉類型
enum Season { Spring,Summer,Fall,Winter; } Season colorful=Season.Fall; Season colorful_1=Season.Summer; //初始化枚舉類型的變量時,只能賦給枚舉中定義的值。
適用於枚舉的運算符
因為枚舉中的字面值只能為整數類型,所以適用於整數類型的運算符都適用於枚舉類型。(bitwise、shift除外)。
Static void doWork() { Season first=Season.Spring; for(int i=0;i<4;i++) { Console.WriteLine(first); //依次輸出Spring,Summer,Fall,Winter. first++; //自增運算符 } Console.WriteLine(first); //此時first超越了枚舉定義的范圍,此時f輸出4。 }
什麼是結構
跟類很相似,有自己的字段,方法,構造方法。
結構有什麼用處
當一個類中存放的數據非常少,此時創建這個類所消耗的內存資源與它所存的數據不成比例。此時,我們可以考慮用結構來代替類。因為結構是值類型,存放在棧上,就減少了內存的開銷。
怎樣定義結構
structure Time { private int hours,minutes,seconds; public Time(int hh, int mm,int ss) { this.hours=hh; this.minutes=mm; this.ss=ss; } pulbic int Hours() { return this.hours; } }
結構與類的區別
結構與類的區別有以下兩種:
1.不能自己定義默認的構造方法.(沒有參數的構造方法)。以下代碼,如果是類,不會報錯。
structure Time { public Time() { //會報錯,結構類型不允許自己定義默認的構造方法。 } }
因為,編譯器在編譯時,如果發現類中沒有構造方法,就會自動生成一個。如果類中有構造方法,就不會自動生成。編譯器不關結構中有沒有構造方法,都會自動生成構造方法。與類中的默認構造方法一樣,結構中的構造方法,會把結構中的字段根據所對應的類型初始化為null,0,false.可以通過非默認構造函數改變字段值。初始化結構中的字段,必須全部初始化。
struct Time { private int hours,minutes,seconds; public Time(int hh, int mm) { this.hours=hh; this.minutes=mm; //會報錯,seconds沒有初始化 } }
2.在類中,我們可以定義字段時初始化,但是在結構中不可以。
struct time { private int hours=0; //報錯,定義時不能初始化 private int minutes; private int seconds; }
理解結構初始化
Time now=new Time(); //我們創建了一個結構類型的對象now。new這個關鍵字調用了Time結構的 //默認構造函數,把它的字段初始化為0. //因為結構是值類型,我們也可以這樣: //Time now; //但是此時,訪問now中的任意成員,都會報錯。因為沒有初始化now中的字段,它們都是 //uninitialized狀態。
我們創建了一個結構類型的對象now。new這個關鍵字調用了Time結構的默認構造函數,把它的字段初始化為0.
因為結構是值類型,我們也可以這樣:
Time now;
但是此時,訪問now中的任意成員,都會報錯。因為沒有初始化now中的字段,它們都是uninitialized狀態。