C99的可变参数宏

你还在#ifdef DEBUG吗?

如何更方便地打印调试信息,一直是困扰我的一大问题。

但自从C99有了可变参数宏后,这样的困扰便不复存在了。


1. __VA_ARGS__

__VA_ARGS__ 将"..." 传递给宏.如

#define dbprint(...) printf(__VA_ARGS__)
#define dbprint(fmt,...) \
             printf(fmt,__VA_ARGS__)
注:

省略号只能代替最后面的宏参数。所以#define W(x,...,y)这样定义是错误的!


2.#

我们使用#把宏参数变为一个字符串。

#define PSQR(x) printf("the square of" #x "is %d.\n",(x)*(x))
int y =4;    
PSQR(y);	//输出the square of y is 16.
PSQR(2+4);	//输出the square of 2+4 is 36.

3.##

##运算符可以用于类函数宏的替换部分。另外,##还可以用于类对象宏的替换部分。这个运算符把两个语言符号组合成单个语言符号。
#define XNAME(n) x##n
#define PXN(n) printf("x"#n" = %d\n",x##n)
int XNAME(1)=12;//int x1=12;
PXN(1);//printf("x1 = %d\n", x1);

4.__FILE__

文件的完整路径和文件名。

5.__LINE__

文件中行数。

6.__FUNCTION__

函数名。

常用调试的宏:


#define pprintf(fmt, ...)         printf(fmt,__VA_ARGS__);

#define db(fmt, ...)  printf("%s:%d %s: debug :"fmt, LS_FILE_NAME, __LINE__, __FUNCTION__, ##__VA_ARGS__);  

#define war(fmt, ...)    printf("%s:%d %s: war :"fmt, LS_FILE_NAME, __LINE__, __FUNCTION__, ##__VA_ARGS__);  

#define err(fmt, ...)  printf("%s:%d %s: error :"fmt, LS_FILE_NAME, __LINE__, __FUNCTION__, ##__VA_ARGS__);  



部分参考:

http://www.cnblogs.com/zhujudah/admin/EditPosts.aspx?opt=1

http://www.cppblog.com/BlueSky/archive/2007/11/20/37000.html


你可能感兴趣的:(c,宏)