可变参数的宏__ VA_ARGS__的用法

描述

回顾

在【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__是整型数据;

其实除了这些还有很多相关的定义,比如:

1.__FUNCTION__:函数名,类型为:字符常量指针。

char const* BuildFunName = __FUNCTION__;

printf("函数名称为:%s ", BuildFunName);

2.__VER__:IDE版本信息,类型为:整型。

如我用的IAR版本为:7.80.04,如下图:

编译

代码:

int IDEVersion = __VER__;

printf("IDE版本:%d ", IDEVersion);

输出:

IDE版本:7080004

更多相关内容,可以自己学会着摸索。而本文讲的内容也是和打印相关,一般都会结合到上面内容一起来使用,详情请看下文。

Ⅰ本文要点--可变参数

我们在学习C语言的时候,都知道printf是可变参数的函数:

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);

上面就是可变参数printf的例子,也就是说参数可以一个也可以多个。而本文说的__VA_ARGS__,就是一个可变参数宏,与printf中可变参数的宏定义一个道理,是新C99规范中增加的。

Ⅱ__VA_ARGS__详情内容

1.关于__VA_ARGS__

__VA_ARGS__它是一个可变参数的宏,就是将左边宏中“...” 的内容原样抄写在右边 __VA_ARGS__ 所在的位置。

要注意的是,printf 的输出格式是括号内左边是字符串,右边是变量,而且右变量与左输出格式是一一对应的,不对应就会出错。可以参看下面那个例子, __VA_ARGS__其实是遵循了printf的格式。

...缺省号代表一个可以变化的参数表。使用保留名 __VA_ARGS__ 把参数传递给宏。当宏的调用展开时,实际的参数就传递给 printf()了。

2.实例说明

#define SENSOR_Printf(...)  printf("--SENSOR--"__VA_ARGS__)

int TemperatureVal = 25;

SENSOR_Printf("温度 = %d℃ ", TemperatureVal);

输出结果:

--SENSOR--温度 = 25℃

用心的朋友可能会猜测的到:“...”类似等于“__VA_ARGS__”。

从例子中我们可以看得出来,__VA_ARGS__的用途,主要是用于可变参数的函数。我们使用较多的printf就是最常见的一个。

如果我们的工程很庞大,我们就可以将打印信息分类,这样的好处就是方便我们识别各类打印信息。

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分