(1) 編譯器處理方式不同
define巨集是在預處理階段展開。
const常量是編譯執行階段使用。
(2) 型別和安全檢查不同
define巨集沒有型別,不做任何型別檢查,僅僅是展開。
const常量有具體的型別,在編譯階段會執行型別檢查。
(3) 儲存方式不同
define巨集僅僅是展開,有多少地方使用,就展開多少次,不會分配記憶體。
const常量會在記憶體中分配(可以是堆中也可以是棧中)。
(4)const 可以節省空間,避免不必要的記憶體分配。 例如:
1#define pi 3.14159 //
常量巨集
2const doulbe pi=3.14159; //
此時並未將pi放入rom中 ......
3double i=pi; //
此時為pi分配記憶體,以後不再分配!
4double i=pi; //
編譯期間進行巨集替換,分配記憶體
5double j=pi; //
沒有記憶體分配
6double j=pi; //
再進行巨集替換,又一次分配記憶體!
const定義常量從彙編的角度來看,只是給出了對應的記憶體位址,而不是象#define一樣給出的是立即數,所以,const定義的常量在程式執行過程中只有乙份拷貝,而 #define定義的常量在記憶體中有若干個拷貝。(5) 提高了效率。 編譯器通常不為普通const常量分配儲存空間,而是將它們儲存在符號表中,這使得它成為乙個編譯期間的常量,沒有了儲存與讀記憶體的操作,使得它的效率也很高。
(6) 有些整合化的除錯工具可以對const常量進行除錯,但是不能對巨集常量進行除錯。
C 基礎2 6盡量用const代替define
2.6盡量用const代替define c define max 1024 c const int max 1024 原因 define定義的巨集從未被編譯器看到過,因為在預處理階段,所有的mac都已經被替換成了1024。如果max不在main裡面,編譯出錯會出現1024,不出現max,不容易解決此...
c 中 defin的基本意思
空指令,無任何效果 include包含乙個源 檔案 define定義巨集 undef取消已定義的巨集 if如果給定條件為真,則編譯下面 ifdef如果巨集已經定義,則編譯下面 ifndef如果巨集沒有定義,則編譯下面 elif如果前面的 if給定條件不為真,當前條件為真,則編譯下面 endif結束乙...
C 中頂層const和底層const
指標本身是乙個物件,由於,指標實際相應著記憶體單元的一段儲存空間,然而,指標所指向的也是乙個資料物件,因此,指標是乙個常量與指標所指向的是乙個常量是兩個全然不同的概念,頂層 const 表示的是 指標本身是乙個常量,底層 const 表示的是 指標所指的物件是乙個常量,更普通情況下,頂層 const...