回顧
在【ANSIC幾種特殊的標準定義】中我們講述了比較常用的幾項:
__FILE__:正在編譯文件的路徑及文件名
__LINE__:正在編譯文件的行號
__DATE__:編譯時刻的日期字符串 如“Jun 17 2017”
__TIME__:編譯時刻的時間字符串 如”1000“
代碼:
char BuildFile[] = __FILE__;
int BuildLine = __LINE__;
char BuildDate[] = __DATE__;
char BuildTime[] = __TIME__;
printf("編譯文件路徑:%s ", BuildFile);
printf("編譯代碼所在行:%d ", TestLine);
printf("編譯日期:%s ", BuildDate);
printf("編譯時間:%s ", BuildTime);
提示:__LINE__是整型數(shù)據(jù);
其實除了這些還有很多相關的定義,比如:
1.__FUNCTION__:函數(shù)名,類型為:字符常量指針。
char const* BuildFunName = __FUNCTION__;
printf("函數(shù)名稱為:%s ", BuildFunName);
2.__VER__:IDE版本信息,類型為:整型。
如我用的IAR版本為:7.80.04,如下圖:
代碼:
intIDEVersion = __VER__;
printf("IDE版本:%d ", IDEVersion);
輸出:
IDE版本:7080004
更多相關內容,可以自己學會著摸索。而本文講的內容也是和打印相關,一般都會結合到上面內容一起來使用,詳情請看下文。
Ⅰ本文要點--可變參數(shù)
我們在學習C語言的時候,都知道printf是可變參數(shù)的函數(shù):
char a = 1;
char b = 2;
char c = 3;
printf("a = %d ", a);
printf("a = %d; b = %d ", a, b);
printf("a = %d; b = %d; c = %d ", a, b, c);
上面就是可變參數(shù)printf的例子,也就是說參數(shù)可以一個也可以多個。而本文說的__VA_ARGS__,就是一個可變參數(shù)宏,與printf中可變參數(shù)的宏定義一個道理,是新C99規(guī)范中增加的。
Ⅱ__VA_ARGS__詳情內容
1.關于__VA_ARGS__
__VA_ARGS__它是一個可變參數(shù)的宏,就是將左邊宏中“...” 的內容原樣抄寫在右邊 __VA_ARGS__ 所在的位置。
要注意的是,printf 的輸出格式是括號內左邊是字符串,右邊是變量,而且右變量與左輸出格式是一一對應的,不對應就會出錯??梢詤⒖聪旅婺莻€例子, __VA_ARGS__其實是遵循了printf的格式。
...缺省號代表一個可以變化的參數(shù)表。使用保留名 __VA_ARGS__ 把參數(shù)傳遞給宏。當宏的調用展開時,實際的參數(shù)就傳遞給 printf()了。
2.實例說明
#defineSENSOR_Printf(...) printf("--SENSOR--"__VA_ARGS__)
intTemperatureVal = 25;
SENSOR_Printf("溫度 = %d℃ ", TemperatureVal);
輸出結果:
--SENSOR--溫度 = 25℃
用心的朋友可能會猜測的到:“...”類似等于“__VA_ARGS__”。
從例子中我們可以看得出來,__VA_ARGS__的用途,主要是用于可變參數(shù)的函數(shù)。我們使用較多的printf就是最常見的一個。
如果我們的工程很龐大,我們就可以將打印信息分類,這樣的好處就是方便我們識別各類打印信息。
-
C語言
+關注
關注
180文章
7614瀏覽量
137775 -
編譯
+關注
關注
0文章
661瀏覽量
33059 -
Printf
+關注
關注
0文章
83瀏覽量
13737
發(fā)布評論請先 登錄
相關推薦
移植vi->venc時提示VA and PA must be page aligned. va=0x70000000, pa=0x10823300,是什么問題?
Techwiz LCD 1D VA顯示模擬建模
ADS8332使用VA=5V VBD=3.3V ,Vref能不能使用2.5V?
ADC128S022斷掉VA和VD的供電,VA依舊有2.2V左右的電壓,為什么?
【RA-Eco-RA2E1-48PIN-V1.0開發(fā)板試用】使用Jlink RTT完成printf打印功能
SV中define宏定義的用法
TINA仿真運放電路時,運放的參數(shù)中是否可以增加溫度參數(shù)呢?
如何讓vasprintF運行?
自建組件中LOGI出錯的原因?
鴻蒙Ability Kit(程序框架服務)【UIAbility組件基本用法】
![鴻蒙Ability Kit(程序框架服務)【UIAbility組件基本<b class='flag-5'>用法</b>】](https://file1.elecfans.com/web2/M00/EC/1E/wKgZomZhJtuAGvhjAACAmnpjgBM543.png)
printf在keil5的AC6編譯器下運行進入死循環(huán)的原因?
STM32U575VGT6 standard request mode配置之后用不了是怎么回事?
宏鑫科技即將掛牌上市
C語言中的可變參數(shù)介紹
![C語言中的<b class='flag-5'>可變</b><b class='flag-5'>參數(shù)</b>介紹](https://file1.elecfans.com/web2/M00/C2/BA/wKgaomXezG6AcBLhAABI4KQSKz0893.png)
評論