const 和 #define 的對比 第一,const與#define的相同點 C++中的const常量類似于宏定義 const int c = 5 ≈ #define c 5 const是用來替換#define的一個手段。
圖片7.png (1.49 KB, 下載次數: 114)
下載附件
2018-3-8 22:52 上傳
圖片8.png (1.81 KB, 下載次數: 129)
下載附件
2018-3-8 22:52 上傳
這兩個程序運行結果都是一樣的,都是定義一個常量a,注意#define最后是沒有分號的。下面這兩個程序也說明了這一點:
圖片9.png (20.2 KB, 下載次數: 121)
下載附件
2018-3-8 22:52 上傳
圖片10.png (3.48 KB, 下載次數: 124)
下載附件
2018-3-8 22:52 上傳
第二,const與#define的不同點 看程序:
圖片11.png (28.5 KB, 下載次數: 113)
下載附件
2018-3-8 22:52 上傳
現在a是一個宏定義,我們知道宏定義,凡是變量a所在的地方預處理編譯器都進行替換,也就是將a替換為10。因此在函數fun1中定義的a在函數fun2中是可以使用的,也就是說宏定義是沒有作用域檢查的。運行可以通過。 那么如果想將a的作用域限制在函數fun1中,可以使用“卸載宏”或者稱作“取消宏” #undef 來達到目的。 #undef a —— 此處往下取消a的宏定義; #undef —— 此處往下取消所有宏定義。 在看看const作用域檢查,我們在fun1中定義變量b,其作用域就局限在fun1函數中了,在fun2函數中是不可用的,可以取消 //printf("b=%d\n",b); 的注釋,發現編譯時錯誤的! 結論: C++中的const常量與宏定義不同 const常量是由編譯器處理的,提供類型檢查和作用域檢查; 宏定義由預處理器處理,單純的文本替換。 【C++】筆記系列均為原創,轉載請注明轉自微號:Lightspeed-Tech 或 AutoCode 更多精彩資料,請關注!
|