日志是游戏调错的重要手段,在这里说说用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__);
当然,你也可以用完整的第三方日志: glog/zlog :看爱好喽。
部分参考:
http://www.cnblogs.com/zhujudah/admin/EditPosts.aspx?opt=1
http://www.cppblog.com/BlueSky/archive/2007/11/20/37000.html