定義常量
在 C++ 中,有兩種簡單的定義常量的方式:
- 使用 #define 預處理器。
- 使用 const 關鍵字。
#define 預處理器
下面是使用 #define 預處理器定義常量的形式:
#define identifier value
具體請看下面的實例:
實例
當上面的代碼被編譯和執行時,它會產生下列結果:
50
const 關鍵字
您可以使用 const 前綴聲明指定類型的常量,如下所示:
const type variable = value;
具體請看下面的實例:
實例
當上面的代碼被編譯和執行時,它會產生下列結果:
50
請注意,把常量定義為大寫字母形式,是一個很好的編程實踐。
宏定義 #define 和常量 const 的區別
類型和安全檢查不同
宏定義是字符替換,沒有數據類型的區別,同時這種替換沒有類型安全檢查,可能產生邊際效應等錯誤;
const常量是常量的聲明,有類型區別,需要在編譯階段進行類型檢查
編譯器處理不同
宏定義是一個"編譯時"概念,在預處理階段展開,不能對宏定義進行調試,生命周期結束與編譯時期;
const常量是一個"運行時"概念,在程序運行使用,類似於一個只讀行數據
存儲方式不同
宏定義是直接替換,不會分配內存,存儲與程序的代碼段中;
const常量需要進行內存分配,存儲與程序的數據段中
定義域不同
void f1 () { #define N 12 const int n 12; } void f2 () { cout<<N <<endl; //正確,N已經定義過,不受定義域限制 cout<<n <<endl; //錯誤,n定義域只在f1函數中 }
定義后能否取消
宏定義可以通過#undef來使之前的宏定義失效
const常量定義后將在定義域內永久有效
void f1() { #define N 12 const int n = 12; #undef N //取消宏定義后,即使在f1函數中,N也無效了 #define N 21//取消后可以重新定義 }
注意:
const限定符定以后是不可以改變的,所以在定義時必須賦初始值,要不然是錯誤的,除非這個變量是用extern修飾的外部變量。
const修飾一個變量,一定要給這個變量初始化值,若不初始化,后面就無法初始化. 例如:
const int A=10; //正確。 const int A; //錯誤,沒有賦初始值。 extern const int A; //正確,使用extern的外部變量。
預處理 #define 變量定義值以后,不能用分號,否則就會計算錯誤,但是程序不會報錯。
#define age 12 #define age1 10 #define age2 12; #define age3 10;
是否可以做函數參數
宏定義不能作為參數傳遞給函數
const常量可以在函數的參數列表中出現
角度1: 就定義常量說的話, const 定義的常數是變量 也帶類型, #define 定義的只是個常數 不帶類型。
角度2: 就起作用的階段而言,#define 是在編譯的預處理階段起作用,而 const 是在 編譯、運行的時候起作用。
角度3: 就起作用的方式而言,#define 只是簡單的字符串替換,沒有類型檢查。而 const 有對應的數據類型,是要進行判斷的,可以避免一些低級的錯誤。 正因為 define 只是簡單的字符串替換會導致邊界效應,具體舉例可以參考下面代碼:
#define N 2+3 // 我們預想的 N 值是 5,我們這樣使用 Ndouble a = N/2; // 我們預想的 a 的值是 2.5,可實際上 a 的值是 3.5
角度4: 就空間占用而言, 例如:
#define PI 3.14 //預處理后 占用代碼段空間 const float PI=3.14; // 本質上還是一個 float,占用數據段空間
角度5: 從代碼調試的方便程度而言, const 常量可以進行調試的,#define 是不能進行調試的,因為在預編譯階段就已經替換掉了
角度6: 從是否可以再定義的角度而言, const 不足的地方,是與生俱來的,const 不能重定義,而 #define 可以通過 #undef 取消某個符號的定義,再重新定義。