巨集定義 define 與 const的區別

2021-08-17 11:26:19 字數 1180 閱讀 5780

#define radius 100;

const  float   radius = 100;

(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) 巨集替換只作替換,不做計算,不做表示式求解;

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

const 與 #define的比較

c++ 語言可以用const來定義常量,也可以用 #define來定義常量。但是前者比後者有更多的優點:

(1)   const常量有資料型別,而巨集常量沒有資料型別。編譯器可以對前者進行型別安全檢查。而對後者只進行字元替換,沒有型別安全檢查,並且在字元替換可能會產生意料不到的錯誤(邊際效應)。

(2)   有些整合化的除錯工具可以對const常量進行除錯,但是不能對巨集常量進行除錯。

define巨集定義和const

define是在預編譯階段就定義的常量,不占用記憶體空間 const可以在程式的任何時候定義,是乙個全域性的常量,放在記憶體的static部分。define巨集定義沒有指定的型別,而const在定義時就指定了常量的型別。const int p p可變,p指向的物件不可變 int const p p可...

巨集定義 define 與常量 const 區別

巨集定義 define 是字元替換,沒有資料型別的區別,同時這種替換沒有型別安全檢查,可能產生邊際效應等錯誤 邊際效應 define n 2 3 我們預想的 n 值是 5,我們這樣使用 ndouble a n 2 我們預想的 a 的值是 2.5,可實際上 a 的值是 3.5const 常量是常量的宣...

const常量與define巨集定義的區別

define radius 100 const float radius 100 1 編譯器處理方式不同 define巨集是在預處理階段展開。const常量是編譯執行階段使用。2 型別和安全檢查不同 define巨集沒有型別,不做任何型別檢查,僅僅是展開。const常量有具體的型別,在編譯階段會執行...