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