宏的使用__VA_ARGS__, __FILE__, __FUNCTION__,__TIME__等

#ifdef DEBUG

#define DebugLog( s, ... ) printf( "<%s:(%d)> %s: %s\n\n", [[[NSString stringWithUTF8String:__FILE__] lastPathComponent] cStringUsingEncoding:NSUTF8StringEncoding], __LINE__,__func__, [[NSString stringWithFormat:(s), ##__VA_ARGS__] cStringUsingEncoding:NSUTF8StringEncoding])

#else

#define DebugLog( s, ... )

#endif


此处 DebugLog( s, ... )的作用是 把它替换成 printf( "<%s:(%d)> %s: %s\n\n", [[[NSString stringWithUTF8String:__FILE__] lastPathComponent] cStringUsingEncoding:NSUTF8StringEncoding], __LINE__,__func__, [[NSString stringWithFormat:(s), ##__VA_ARGS__] cStringUsingEncoding:NSUTF8StringEncoding])


1. __VA_ARGS__:总体来说就是将左边宏中"( s, ... )" 的内容原样抄写在右边 __VA_ARGS__ 所在的位置,它是一个可变参数的宏。要注意的是,printf 的输出格式是括号内左边是字符串,右边是变量,而且右变量与左输出格式是一一对应的,用法和NSLog差不多。

宏前面加上##的作用在于,当可变参数的个数为0时,这里的##起到把前面多余的","去掉的作用,否则会编译出错, 你可以试试。

实现思想就是宏定义中参数列表的最后一个参数为省略号(也就是三个点)。这样预定义宏_ _VA_ARGS_ _就可以被用在替换部分中,替换省略号所代表的字符串

2. __FILE__ :宏在预编译时会替换成当前的源文件名

3. __LINE__:宏在预编译时会替换成当前的行号

4. __FUNCTION__:宏在预编译时会替换成当前的函数名称

5. __TIME__:宏在预编译时会替换成系统的当前时间

6.__TIMESTAMP__:和第五点类似

7.##运算符可以用于类函数宏的替换部分。另外,##还可以用于类对象宏的替换部分。这个运算符把两个语言符号组合成单个语言符号

例:

DebugLog(@"123");


输出:

<ViewController.m:(34)> 11:40:14Tue Jan 12 11:11:16 2016 -[ViewController viewDidLoad]: 123



了解更多:http://www.cnblogs.com/pengyingh/articles/2407265.html



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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值