enum和巨集定義的區別以及其使用

2021-06-21 15:21:02 字數 1163 閱讀 1068

首先是enum的使用一段簡單的**:

#include

#include

using namespace std;

enum day;

void test(int sunny)

return 0;}

關於為什麼使用列舉型別和好處:相比簡單的數字0,1.使程式更有可讀性。下面將與巨集定義進行乙個比較。

(1) 編譯器處理方式不同

define巨集是在預處理階段展開。

const常量是編譯執行階段使用。

(2) 型別和安全檢查不同

define巨集沒有型別,不做任何型別檢查,僅僅是展開。

const常量有具體的型別,在編譯階段會執行型別檢查。

(3) 儲存方式不同

define巨集僅僅是展開,有多少地方使用,就展開多少次,不會分配記憶體。(巨集定義不分配記憶體,變數定義分配記憶體。)

const常量會在記憶體中分配(可以是堆中也可以是棧中)。

(4)const  可以節省空間,避免不必要的記憶體分配。 例如:  

#define pi 3.14159 //常量巨集  

const doulbe pi=3.14159; //此時並未將pi放入rom中 ......  

double i=pi; //此時為pi分配記憶體,以後不再分配!  

double i=pi; //編譯期間進行巨集替換,分配記憶體  

double j=pi; //沒有記憶體分配  

double j=pi; //再進行巨集替換,又一次分配記憶體!  

const定義常量從彙編的角度來看,只是給出了對應的記憶體位址,而不是象#define一樣給出的是立即數,所以,const定義的常量在程式執行過程中只有乙份拷貝(因為是全域性的唯讀變數,存在靜態區),而 #define定義的常量在記憶體中有若干個拷貝。 

(5) 提高了效率。 編譯器通常不為普通const常量分配儲存空間,而是將它們儲存在符號表中,這使得它成為乙個編譯期間的常量,沒有了儲存與讀記憶體的操作,使得它的效率也很高。

(6) 巨集替換只作替換,不做計算,不做表示式求解;

巨集預編譯時就替換了,程式執行時,並不分配記憶體。

在enum中的巨集定義

今天在 裡看到有一點很奇怪的 定義了乙個列舉型別,但是這個列舉型別沒有變數名,而且在其中包含了巨集定義,巨集定義也是自己定義自己 enum 然後搜到了以下的解釋 enum 以前的版本中 pthread cancel enable 和 pthread cancel disable 都是定義為以下巨集的...

typedef和巨集定義的區別

posted on 2010 年 11 月 8 日 因為資料結構課程中,typedef和巨集定義的經常使用。前幾日室友問我typedef和巨集定義有什麼區別,我一時無法回答,隱約只記得typedef和定義在陣列方面和指標方面有區別。這兩天,為了解決自己的盲點,google了這個問題,做幾點總結。de...

const和巨集定義的區別!!!

巨集的命名規範 一般以專案字首開頭,key結尾。開頭表編譯。巨集的用法 1 定義常用字串。2 定義一段 const與巨集的區別 1 編譯時刻 巨集 預編譯 const command b 編譯階段 編譯。2 巨集不會檢查 錯誤,只是替換,但是const會編譯報錯。3 巨集的好處 定義 或字串 方法 ...