预定义调试时 省略号(...)和 ##__VA_ARGS__ 的作用

参见例子

#define SHOWINFO_ON

#ifdef  SHOWINFO_ON
#define showFuncInfo(format_MACRO, ...)  printf("FILE: %s , LINE: %d: " format_MACRO "\n",__FILE__, __LINE__,##__VA_ARGS__)
#else
#define showFuncInfo(format_MACRO, ...)
#endif

新建h文件,粘贴上面代码,main中测试时,当注释掉 #define SHOWINFO_ON 语句时,#else 部分生效,则showFuncInfo的功能就是啥也不做! 当#define SHOWINFO_ON 语句生效时,#ifdef部分语句生效,此时showFuncInfo(format_MACRO, ...)就等效于printf("FILE: %s , LINE: %d: " format_MACRO "\n",__FILE__, __LINE__,##__VA_ARGS__),此时,

showFuncInfo("%s", “abc”);<==>printf("FILE: %s , LINE: %d:  %s \n",__FILE__, __LINE__, “abc”);

也就是说,format_MACRO表示格式符,...为参数列表,在展开时时被##__VA_ARGS__替代,注意format_MACRO在printf的双引号,和##__VA_ARGS__在printf中的位置。 

这样做的好处就是,无论输出多少个参数值,都可以以上面这种统一的形式进行输出实现!

猜你喜欢

转载自blog.csdn.net/chunfangzhang/article/details/82112109