使用nslog的一个风险是:它的运行会占用时间和设备资源。
简单而粗暴的解决方案是:在release前,将所有的nslog注释掉。简单有效,但副作用是:下次你要调试时,又得将nslog一个个取消注释。
以release模式编译的程序不会用nslog输出,而以debug模式编译的程序将执行nslog的全部功能。
解决步骤:
修改<appname>-prefix.pch ,增加以下的宏代码
#ifdef debug
# define dlog(fmt, ...) nslog((@"[文件名:%s]\n" "[函数名:%s]\n" "[行号:%d] \n" fmt), __file__, __function__, __line__, ##__va_args__);
#else
# define dlog(...);
#endif
在程序中使用dlog来替换原来的nslog
dlog(@"当前程序目录是:%@", [self applicationdocumentsdirectory ]);
修改项目的配置,使得在debug编译的时候,编译dlog的宏,产生详细的日志信息,而release的时候,不产生任何控制台输出
在other linker flags 中,在debug的时候,加入编译属性 -debug
这样控制台会显示这样的日志信息
2011-12-27 22:23:53.303 imanager[5449:b603] [文件名:/users/roamer/project/ÂõΩÊ≥∞ÂêõÂÆâ/Ëꕉ∏öÈÉ®ÁưÁêÜiphone/imanager/imanager/appdelegate.m]
[函数名:-[appdelegate application:didfinishlaunchingwithoptions:]]
[行号:37]
当前程序目录是:/users/roamer/library/application support/iphone simulator/4.3.2/applications/6b0e7b08-5528-468a-b728-0c4580805368/documents
补充:
1) __va_args__ 是一个可变参数的宏,很少人知道这个宏,这个可变参数的宏是新的c99规范中新增的,目前似乎只有gcc支持(vc6.0的编译器不支持)。宏前面加上##的作用在于,当可变参数的个数为0时,这里的##起到把前面多余的","去掉的作用,否则会编译出错,
你可以试试。
2) __file__ 宏在预编译时会替换成当前的源文件名
3) __line__宏在预编译时会替换成当前的行号
4) __function__宏在预编译时会替换成当前的函数名称
#define devide_line
"\n>>>> =========================================== <<<< \n"
# define mylog(fmt, ...) nslog((@devide_line
"%s , " "[行号:%d] " fmt) , __function__, __line__, ##__va_args__);
#define ll_log(fmt, ...) mylog(@" \n>> ll print << \n " fmt devide_line, ##__va_args__);