程序大了的时候Log信息过于繁杂, 看起来十分不方便, 为了在使用Log时输出更多有用的信息可以使用NSLog的一些进阶功能
· 定义以下宏:
#ifdef DEBUG
# define DLog(fmt, ...) NSLog((@"[文件名:%s]\n" "[函数名:%s]\n" "[行号:%d] \n" fmt), __FILE__, __FUNCTION__, __LINE__, ##__VA_ARGS__);
#else
# define DLog(...);
#endif
参数解释:
1.VA_ARGS是一个可变参数的宏,很少人知道这个宏,这个可变参数的宏是新的C99规范中新增的,目前似乎只有gcc支(VC6.0的编译器不支持)。宏前面加上##的作用在于,当可变参数的个数为0时,这里的##起到把前面多余的","去掉的作用,否则会编译出错, 你可以试试。
2.FILE宏在预编译时会替换成当前的源文件名
3.LINE宏在预编译时会替换成当前的行号
4.FUNCTION宏在预编译时会替换成当前的函数名称
有了以上这几个宏,特别是有了VA_ARGS,调试信息的输出就变得灵活多了。
看完这段解释,读者应该对自定义NSLog有更深的理解了。
参考
http://www.cnblogs.com/GarveyCalvin/p/4157553.html
http://blog.csdn.net/laomai/article/details/276274
http://stackoverflow.com/questions/21873616/how-to-use-va-args-properly