標題: [C++]筆記二十:const 和 #define 的對比 [打印本頁]
作者: tyyhmtyyhm 時間: 2018-3-8 22:53
標題: [C++]筆記二十:const 和 #define 的對比
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
更多精彩資料,請關注!
| 歡迎光臨 (http://m.raoushi.com/bbs/) |
Powered by Discuz! X3.1 |