天天看点

在ios iphone编程中使用封装的NSLog来打印调试信息

使用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

在ios iphone编程中使用封装的NSLog来打印调试信息

这样控制台会显示这样的日志信息

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__);