日志是游戏调错的重要手段,在这里说说用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
本文介绍如何利用C99的可变参数宏进行高效的日志打印,包括__VA_ARGS__、#、##等宏的使用技巧,并展示了如何结合__FILE__、__LINE__和__FUNCTION__等预定义宏来增强调试信息。
&spm=1001.2101.3001.5002&articleId=9020253&d=1&t=3&u=aaf30716473846d5a5ae769a9d1995bc)
4348

被折叠的 条评论
为什么被折叠?



