C語(yǔ)言中#define預(yù)處理語(yǔ)法總結(jié)
一、使用#define定義標(biāo)識(shí)符常量
語(yǔ)法1:
#define MAX 100
注意使用#define末尾不需要帶;
MAX是一個(gè)常量,是使用#define定義的一個(gè)標(biāo)識(shí)符常量 ?。?!
我為什么要在這里強(qiáng)調(diào)這是一個(gè)常量呢?因?yàn)樗推胀ǔA恳粯硬豢杀恍薷?/p>
大家可能會(huì)疑惑使用const修飾的變量不也是不可被修改的嗎,這兩者有什么不同呢?
這里要強(qiáng)調(diào)一下,使用const修飾的變量叫做常變量,雖然指不能被修改,但其本質(zhì)是變量
常量與常變量的不同:
這是嘗試用編譯器編譯時(shí)報(bào)的錯(cuò)誤
注意:
不要用#define去替代一個(gè)類(lèi)型比如
#define INT int int main(){ INT a=10; return 0; }
這樣用#define沒(méi)什么錯(cuò),但是最好用typedef來(lái)給類(lèi)型重命名即
typedef INT int; int main(){ INT a=10; return 0; }
使用#define進(jìn)行類(lèi)型重命名的陷阱
#define INT_PTK int* typedef int* INT_PTR; int main() { INT_PTK a, b; INT_PTR c, d; //a,b,c,d中只有b不是指針,因?yàn)閕nt *a,b;//b是整型 // Typedef int * INT_PTR中的int*是一個(gè)完整的類(lèi)型和float一樣不可拆分 return 0; }
解釋一下為什么只有b不是指針,編譯時(shí)編譯器會(huì)將INT_PTK替換為int* a,b;
注意其中int與*不是一個(gè)整體,因?yàn)檫@是#define的規(guī)則,它無(wú)法識(shí)別int*是一個(gè)整體,
于是*優(yōu)先與a結(jié)合,結(jié)果其實(shí)是int *a; int b;
使用typedef自然沒(méi)有這個(gè)陷阱
語(yǔ)法2:
#define MAX
可以看到這后面并沒(méi)有跟數(shù)據(jù),可是不跟數(shù)據(jù)的標(biāo)識(shí)符常量的使用場(chǎng)景是什么呢?
使用場(chǎng)景:結(jié)合條件編譯來(lái)使用
//這是一個(gè)自定義的頭文件 #ifndef __define__ #define __define__ int Add(int x,int y) { return x+y; } #endif
這樣就可以防止在一個(gè)工程當(dāng)中該頭文件被重復(fù)包含了
二、#define來(lái)定義帶有參數(shù)的宏
#define機(jī)制包括了一個(gè)規(guī)定,允許把參數(shù)替換到文本中,這種實(shí)現(xiàn)通常稱為宏(macro)或定義宏(define macro)。
#include<stdio.h> #define MIN(x,y) (x>y?y:x)//#define來(lái)定義帶有參數(shù)的宏,宏的定義 int min(int x, int y)//功能與上述宏相同 { if (x > y) return y; else return x; } int main() { int b = 10, c = 19; printf("MIN=%d\n", MIN(b, c)); printf("min=%d\n", min(b, c)); return 0; }
MIN(b,c)與min(b,c)功能一模一樣,完成了對(duì)兩個(gè)數(shù)據(jù)比較大小的功能
可見(jiàn)有時(shí)候使用宏比定義一個(gè)函數(shù)要省時(shí)省力的多(定義一個(gè)函數(shù),哪怕這個(gè)函數(shù)再簡(jiǎn)單其在系統(tǒng)上的開(kāi)銷(xiāo)是不小的)
三、C語(yǔ)言給我們定義好的一些標(biāo)識(shí)符常量
__FILE__ //進(jìn)行編譯的源文件
__LINE__ //文件當(dāng)前的行號(hào)
__DATE__ //文件被編譯的日期
__TIME__ //文件被編譯的時(shí)間
__FUNCTION__ //進(jìn)行編譯的函數(shù)
__STDC__ //如果編譯器遵循ANSI C,其值為1,否則未定義(VS不支持,gcc是完全遵循C標(biāo)準(zhǔn)的)
這些都是可以直接使用的
gcc編譯器下
到此這篇關(guān)于C語(yǔ)言中#define預(yù)處理語(yǔ)法總結(jié)的文章就介紹到這了,更多相關(guān)C語(yǔ)言 #define預(yù)處理內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語(yǔ)言深度解剖篇之關(guān)鍵字以及補(bǔ)充內(nèi)容
C語(yǔ)言的關(guān)鍵字共有32個(gè),根據(jù)關(guān)鍵字的作用,可分其為數(shù)據(jù)類(lèi)型關(guān)鍵字、控制語(yǔ)句關(guān)鍵字、存儲(chǔ)類(lèi)型關(guān)鍵字和其它關(guān)鍵字四類(lèi),這篇文章主要給大家介紹了關(guān)于C語(yǔ)言深度解剖篇之關(guān)鍵字以及補(bǔ)充內(nèi)容的相關(guān)資料,需要的朋友可以參考下2022-06-06C++?protobuf中對(duì)不同消息內(nèi)容進(jìn)行賦值的方式總結(jié)(set_、set_allocated_、mutable_、
這篇文章主要給大家介紹了關(guān)于C++?protobuf中對(duì)不同消息內(nèi)容進(jìn)行賦值的方式總結(jié),主要使用的是set_、set_allocated_、mutable_、add_,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-03-03C++實(shí)現(xiàn)二叉樹(shù)基本操作詳解
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)二叉樹(shù)基本操作,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-12-12C++程序的執(zhí)行順序結(jié)構(gòu)以及關(guān)系和邏輯運(yùn)算符講解
這篇文章主要介紹了C++程序的執(zhí)行順序結(jié)構(gòu)以及關(guān)系和邏輯運(yùn)算符講解,是C++入門(mén)學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2015-09-09C語(yǔ)言計(jì)算連續(xù)無(wú)序數(shù)組中缺省數(shù)字方法詳解
這篇文章主要介紹了C語(yǔ)言計(jì)算連續(xù)無(wú)序數(shù)組中缺省數(shù)字方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧2023-02-02C語(yǔ)言中無(wú)符號(hào)數(shù)和有符號(hào)數(shù)之間的運(yùn)算
C語(yǔ)言中有符號(hào)數(shù)和無(wú)符號(hào)數(shù)進(jìn)行運(yùn)算默認(rèn)會(huì)將有符號(hào)數(shù)看成無(wú)符號(hào)數(shù)進(jìn)行運(yùn)算,其中算術(shù)運(yùn)算默認(rèn)返回?zé)o符號(hào)數(shù),邏輯運(yùn)算當(dāng)然是返回0或1了。下面通過(guò)一個(gè)例子給大家分享C語(yǔ)言中無(wú)符號(hào)數(shù)和有符號(hào)數(shù)之間的運(yùn)算,一起看看吧2017-09-09