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