开发调试中,一些不常见的但实用的宏

1.常见常用的宏可以放在PCH文件中,配置需要注意一个问题,配置文件路径一个简单的解决方式就是 项目名+/+PCH文件名例如:PCHTest/PrefixHeader.pch

2.NSLog宏 应该说NSLog打印信息是初学者最喜欢的调试手法,也是最简单的调试,通过打印出的信息查看程序运行的路径。但是打印出的信息较少,本身NSLog效率较低,有人使用宏做了部分优化,代码如下:能够打印出所在类名、所在方法名、详细时间、行号。

ifdef DEBUG
define CWGLog(format, ...) NSLog((@"[文件名:%s]\n" "[函数名:%s]\n" "[行号:%d] \n" format), **FILE**, **FUNCTION**, **LINE**, ##**VA_ARGS**);
else
define CWGLog(...);
endif

参数说明: VA_ARGS 是一个可变参数的宏,很少人知道这个宏,这个可变参数的宏是新的C99规范中新增的,目前似乎只有gcc支持(VC6.0的编译器不支持)。宏前面加上##的作用在于,当可变参数的个数为0时,这里的##起到把前面多余的","去掉的作用,否则会编译出错, 你可以试试。

3.代码运行时间

define Start [NSDate date]
define End NSLog(@"执行耗时%f", -[Start timeIntervalSinceNow]);

使用

Start;
NSString *str = @"asd";NSLog(@"%@",str);
End;

输出结果:耗时0.000006

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容