C語言中幾種特殊標(biāo)準(zhǔn)定義和用法
__FILE__:正在編譯文件的路徑及文件名
__LINE__:正在編譯文件的行號
__DATE__:編譯時刻的日期字符串 如“July 19 2019”
__TIME__:編譯時刻的時間字符串 如”22:00:00“
代碼:
char BuildFile[] = __FILE__;
int BuildLine = __LINE__;
char BuildDate[] = __DATE__;
char BuildTime[] = __TIME__;
printf("編譯文件路徑:%s\n", BuildFile);
printf("編譯代碼所在行:%d\n", TestLine);
printf("編譯日期:%s\n", BuildDate);
printf("編譯時間:%s\n", BuildTime);
char const* BuildFunName = __FUNCTION__;
printf("函數(shù)名稱為:%s\n", BuildFunName);
int IDEVersion = __VER__;
printf("IDE版本:%d\n", IDEVersion);
輸出:
IDE版本:7080004
我們在學(xué)習(xí)C語言的時候,都知道printf是可變參數(shù)的函數(shù):
char a = 1;
char b = 2;
char c = 3;
printf("a = %d\n", a);
printf("a = %d; b = %d\n", a, b);
printf("a = %d; b = %d; c = %d\n", a, b, c);
上面就是可變參數(shù)printf的例子,也就是說參數(shù)可以一個也可以多個。
而接下來說的__VA_ARGS__,就是一個可變參數(shù)宏,與printf中可變參數(shù)的宏定義一個道理,是新C99規(guī)范中增加的。
1.關(guān)于__VA_ARGS__
__VA_ARGS__它是一個可變參數(shù)的宏,就是將左邊宏中“...” 的內(nèi)容原樣抄寫在右邊 __VA_ARGS__ 所在的位置。
要注意的是,printf 的輸出格式是括號內(nèi)左邊是字符串,右邊是變量,而且右變量與左輸出格式是一一對應(yīng)的,不對應(yīng)就會出錯。可以參看下面那個例子, __VA_ARGS__其實是遵循了printf的格式。
...缺省號代表一個可以變化的參數(shù)表。使用保留名 __VA_ARGS__ 把參數(shù)傳遞給宏。當(dāng)宏的調(diào)用展開時,實際的參數(shù)就傳遞給 printf()了。
2.實例說明
int TemperatureVal = 25;
SENSOR_Printf("溫度 = %d℃\n", TemperatureVal);
輸出結(jié)果:
--SENSOR--溫度 = 25℃
用心的朋友可能會猜測的到:“...”類似等于“__VA_ARGS__”。
從例子中我們可以看得出來,__VA_ARGS__的用途,主要是用于可變參數(shù)的函數(shù)。我們使用較多的printf就是最常見的一個。
如果我們的工程很龐大,我們就可以將打印信息分類,這樣的好處就是方便我們識別各類打印信息。
長按前往圖中包含的公眾號關(guān)注
免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺僅提供信息存儲服務(wù)。文章僅代表作者個人觀點,不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!