C語言中#define預(yù)處理語法總結(jié)
一、使用#define定義標(biāo)識符常量
語法1:
#define MAX 100
注意使用#define末尾不需要帶;
MAX是一個(gè)常量,是使用#define定義的一個(gè)標(biāo)識符常量 ?。?!
我為什么要在這里強(qiáng)調(diào)這是一個(gè)常量呢?因?yàn)樗推胀ǔA恳粯硬豢杀恍薷?/p>
大家可能會(huì)疑惑使用const修飾的變量不也是不可被修改的嗎,這兩者有什么不同呢?
這里要強(qiáng)調(diào)一下,使用const修飾的變量叫做常變量,雖然指不能被修改,但其本質(zhì)是變量
常量與常變量的不同:


這是嘗試用編譯器編譯時(shí)報(bào)的錯(cuò)誤
注意:
不要用#define去替代一個(gè)類型比如
#define INT int
int main(){
INT a=10;
return 0;
}
這樣用#define沒什么錯(cuò),但是最好用typedef來給類型重命名即
typedef INT int;
int main(){
INT a=10;
return 0;
}
使用#define進(jìn)行類型重命名的陷阱
#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è)完整的類型和float一樣不可拆分
return 0;
}
解釋一下為什么只有b不是指針,編譯時(shí)編譯器會(huì)將INT_PTK替換為int* a,b;
注意其中int與*不是一個(gè)整體,因?yàn)檫@是#define的規(guī)則,它無法識別int*是一個(gè)整體,
于是*優(yōu)先與a結(jié)合,結(jié)果其實(shí)是int *a; int b;
使用typedef自然沒有這個(gè)陷阱
語法2:
#define MAX
可以看到這后面并沒有跟數(shù)據(jù),可是不跟數(shù)據(jù)的標(biāo)識符常量的使用場景是什么呢?
使用場景:結(jié)合條件編譯來使用
//這是一個(gè)自定義的頭文件
#ifndef __define__
#define __define__
int Add(int x,int y)
{
return x+y;
}
#endif
這樣就可以防止在一個(gè)工程當(dāng)中該頭文件被重復(fù)包含了
二、#define來定義帶有參數(shù)的宏
#define機(jī)制包括了一個(gè)規(guī)定,允許把參數(shù)替換到文本中,這種實(shí)現(xiàn)通常稱為宏(macro)或定義宏(define macro)。
#include<stdio.h>
#define MIN(x,y) (x>y?y:x)//#define來定義帶有參數(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)功能一模一樣,完成了對兩個(gè)數(shù)據(jù)比較大小的功能
可見有時(shí)候使用宏比定義一個(gè)函數(shù)要省時(shí)省力的多(定義一個(gè)函數(shù),哪怕這個(gè)函數(shù)再簡單其在系統(tǒng)上的開銷是不小的)
三、C語言給我們定義好的一些標(biāo)識符常量
__FILE__ //進(jìn)行編譯的源文件
__LINE__ //文件當(dāng)前的行號
__DATE__ //文件被編譯的日期
__TIME__ //文件被編譯的時(shí)間
__FUNCTION__ //進(jìn)行編譯的函數(shù)
__STDC__ //如果編譯器遵循ANSI C,其值為1,否則未定義(VS不支持,gcc是完全遵循C標(biāo)準(zhǔn)的)
這些都是可以直接使用的
gcc編譯器下


到此這篇關(guān)于C語言中#define預(yù)處理語法總結(jié)的文章就介紹到這了,更多相關(guān)C語言 #define預(yù)處理內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語言深度解剖篇之關(guān)鍵字以及補(bǔ)充內(nèi)容
C語言的關(guān)鍵字共有32個(gè),根據(jù)關(guān)鍵字的作用,可分其為數(shù)據(jù)類型關(guān)鍵字、控制語句關(guān)鍵字、存儲(chǔ)類型關(guān)鍵字和其它關(guān)鍵字四類,這篇文章主要給大家介紹了關(guān)于C語言深度解剖篇之關(guān)鍵字以及補(bǔ)充內(nèi)容的相關(guān)資料,需要的朋友可以參考下2022-06-06
輕松實(shí)現(xiàn)C/C++各種常見進(jìn)制相互轉(zhuǎn)換
這篇文章主要介紹了輕松實(shí)現(xiàn)C/C++各種常見進(jìn)制相互轉(zhuǎn)換,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11
文件編譯時(shí)出現(xiàn)multiple definition of ''xxxxxx''的具體解決方法
以下是對文件編譯時(shí)出現(xiàn)multiple definition of 'xxxxxx'的解決方法進(jìn)行了詳細(xì)的分析介紹,如也遇到此問題的朋友們可以過來參考下2013-07-07
C++11 寫一個(gè)只觸發(fā)一次槽函數(shù)的Qt connect函數(shù)
這篇文章主要為大家介紹了C++11 寫一個(gè)只觸發(fā)一次槽函數(shù)的Qt connect函數(shù)實(shí)例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09
C++中二進(jìn)制數(shù)據(jù)序列化和反序列化詳解
這篇文章主要為大家詳細(xì)介紹了C++中二進(jìn)制數(shù)據(jù)序列化和反序列化的相關(guān)知識,文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價(jià)值,感興趣的小伙伴可以了解下2023-11-11
C++利用stringstream進(jìn)行數(shù)據(jù)類型轉(zhuǎn)換實(shí)例
這篇文章主要介紹了C++利用stringstream進(jìn)行數(shù)據(jù)類型轉(zhuǎn)換的方法,實(shí)例分析了使用stringstream進(jìn)行string轉(zhuǎn)int的操作技巧,需要的朋友可以參考下2015-01-01

