日志打印(C99的可变参数宏实例)

日志是游戏调错的重要手段,在这里说说用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


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值