C說話 列舉類型(Enum)詳解及示例代碼。本站提示廣大學習愛好者:(C說話 列舉類型(Enum)詳解及示例代碼)文章只能為提供參考,不一定能成為您想要的結果。以下是C說話 列舉類型(Enum)詳解及示例代碼正文
在現實編程中,有些數據的取值常常是無限的,只能長短常大批的整數,而且最好為每一個值都取一個名字,以便利在後續代碼中應用,好比一個禮拜只要七天,一年只要十二個月,一個班每周有六門課程等。
以每周七天為例,我們可使用#define敕令來給天天指定一個名字:
#include <stdio.h> #define Mon 1 #define Tues 2 #define Wed 3 #define Thurs 4 #define Fri 5 #define Sat 6 #define Sun 7 int main(){ int day; scanf("%d", &day); switch(day){ case Mon: puts("Monday"); break; case Tues: puts("Tuesday"); break; case Wed: puts("Wednesday"); break; case Thurs: puts("Thursday"); break; case Fri: puts("Friday"); break; case Sat: puts("Saturday"); break; case Sun: puts("Sunday"); break; default: puts("Error!"); } return 0; }
運轉成果:
5↙
Friday
#define敕令固然能處理成績,但也帶來了不小的反作用,招致宏名過量,代碼松懈,看起來總有點不舒暢。C說話供給了一種列舉(Enum)類型,可以或許列出一切能夠的取值,並給它們取一個名字。
列舉類型的界說情勢為:
enum typeName{ valueName1, valueName2, valueName3, ...... };
enum是一個新的症結字,專門用來界說列舉類型,這也是它在C說話中的獨一用處;typeName是列舉類型的名字;
valueName1, valueName2, valueName3, ......是每一個值對應的名字的列表。留意最初的;不克不及少。
例如,列出一個禮拜有幾天:
enum week{ Mon, Tues, Wed, Thurs, Fri, Sat, Sun };
可以看到,我們僅僅給出了名字,卻沒有給知名字對應的值,這是由於列舉值默許從 0 開端,往後逐一加 1(遞增);也就是說,week 中的 Mon、Tues ...... Sun 對應的值分離為 0、1 ...... 6。
我們也能夠給每一個名字都指定一個值:
enum week{ Mon = 1, Tues = 2, Wed = 3, Thurs = 4, Fri = 5, Sat = 6, Sun = 7 };
更加簡略的辦法是只給第一個名字指定值:
enum week{ Mon = 1, Tues, Wed, Thurs, Fri, Sat, Sun };
如許列舉值就從 1 開端遞增,跟下面的寫法是等效的。
列舉是一品種型,經由過程它可以界說列舉變量:
enum week a, b, c;
也能夠在界說列舉類型的同時界說變量:
enum week{ Mon = 1, Tues, Wed, Thurs, Fri, Sat, Sun } a, b, c;
有了列舉變量,便可以把列表中的值賦給它:
enum week{ Mon = 1, Tues, Wed, Thurs, Fri, Sat, Sun };
enum week a = Mon, b = Wed, c = Sat;
或許:
enum week{ Mon = 1, Tues, Wed, Thurs, Fri, Sat, Sun } a = Mon, b = Wed, c = Sat;
【示例】斷定用戶輸出的是禮拜幾。
#include <stdio.h> int main(){ enum week{ Mon = 1, Tues, Wed, Thurs, Fri, Sat, Sun } day; scanf("%d", &day); switch(day){ case Mon: puts("Monday"); break; case Tues: puts("Tuesday"); break; case Wed: puts("Wednesday"); break; case Thurs: puts("Thursday"); break; case Fri: puts("Friday"); break; case Sat: puts("Saturday"); break; case Sun: puts("Sunday"); break; default: puts("Error!"); } return 0; }
運轉成果:
4↙
Thursday
須要留意的兩點是:
1) 列舉列表中的 Mon、Tues、Wed 這些標識符的感化規模是全局的,不克不及再界說與它們名字雷同的變量。
2) Mon、Tues、Wed 等都是常量,不克不及對它們賦值,只能將它們的值賦給其他的變量。
列舉和宏其實異常相似:宏在預處置階段將名字調換成對應的值,列舉在編譯階段將名字調換成對應的值。我們可以將列舉懂得為編譯階段的宏。
關於下面的代碼,在編譯的某個時辰會釀成相似上面的模樣:
#include <stdio.h> int main(){ enum week{ Mon = 1, Tues, Wed, Thurs, Fri, Sat, Sun } day; scanf("%d", &day); switch(day){ case 1: puts("Monday"); break; case 2: puts("Tuesday"); break; case 3: puts("Wednesday"); break; case 4: puts("Thursday"); break; case 5: puts("Friday"); break; case 6: puts("Saturday"); break; case 7: puts("Sunday"); break; default: puts("Error!"); } return 0; }
Mon、Tues、Wed 這些名字都被調換成了對應的數字。這意味著,Mon、Tues、Wed 等都不是變量,它們不占用數據區(常量區、全局數據區、棧區和堆區)的內存,而是直接被編譯到敕令外面,放到代碼區,所以不克不及用&獲得它們的地址。這就是列舉的實質。
關於法式在內存中的分區和各個分區的感化,我們將在《C說話內存》專題中的《Linux下C說話法式的內存結構(內存模子)》一節中具體講授。
我們在《C說話switch語句》一節中講過,case 症結字前面必需是一個整數,或許是成果為整數的表達式,但不克不及包括任何變量,恰是因為 Mon、Tues、Wed 這些名字終究會被調換成一個整數,所以它們能力放在 case 前面。
構造體變量須要寄存的是一個整數,我猜想它的長度和 int 應當雷同,上面來驗證一下:
#include <stdio.h> int main(){ enum week{ Mon = 1, Tues, Wed, Thurs, Fri, Sat, Sun } day = Mon; printf("%d, %d, %d, %d, %d\n", sizeof(enum week), sizeof(day), sizeof(Mon), sizeof(Wed), sizeof(int) ); return 0; }
運轉成果:
4, 4, 4, 4, 4
以上就是對 C說話列舉類型的材料整頓,後續持續彌補相干材料,感謝年夜家對本站的支撐!