参见例子
#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中的位置。
这样做的好处就是,无论输出多少个参数值,都可以以上面这种统一的形式进行输出实现!