iOS 之 NSLog 打印

开发过程中经常会伴随着NSLog的调试打印信息,但是:一方面NSLog会占用一些系统的资源,另外一方面,在发布到商店,用户下载运行在设备上用户也看不到,所以一般在上线的时候需要把这些NSLog的代码“删掉”,其实就是想让它不执行,如果把他们全部删除又会导致接下来的开发调试得重新写NSLog,同时删除也会浪费一部分开发同学的精力,那我们可以使用

__OPTIMIZE__

来解决这个问题。

// 以release模式编译的程序不会用NSLog输出,而以debug模式编译的程序将执行NSLog的全部功能。

#ifndef __OPTIMIZE__
# define NSLog(...) NSLog(__VA_ARGS__)
#else
# define NSLog(...)
#endif

#ifdef __OPTIMIZE__
#define NSLog(...) 
#endif

这个代码的魔术在于:release模式通常会定义 __OPTIMIZE__,debug模式不会。

将这段代码放在头文件当中,就可以放心的使用NSLog了!

把这些代码放到*Prefix.pch中最省事。可以把这段宏定义放到一个头文件中,再把这个头文件包含到*Prefix.pch中。

原文:http://lichen1985.com/blog/?p=251



你可能感兴趣的:(iOS 之 NSLog 打印)