keil中使用——变参数宏__VA_ARGS__

本文说的__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℃\n", TemperatureVal);

 

输出结果:

--SENSOR--温度 = 25℃

 

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

 

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

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

 

我自己在项目中使用的方法如下:

#define _MSG_DBG(...)   SEGGER_RTT_printf(0, __VA_ARGS__);      //RTT打印

如果不想打印,就使用下面的:

#define _MSG_DBG(...) 

即可

 

参考了strongerHuang 的博客

posted @ 2019-12-16 13:35  wdliming  阅读(2189)  评论(0编辑  收藏  举报