美文网首页
开发调试中,一些不常见的但实用的宏

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

作者: 名扬丶四海 | 来源:发表于2016-05-17 16:31 被阅读24次

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

相关文章

网友评论

      本文标题:开发调试中,一些不常见的但实用的宏

      本文链接:https://www.haomeiwen.com/subject/syuirttx.html