关于Debug下的Log打印问题

时间:2023-11-22 23:54:20

在项目中为了调试经常会用到Log打印,比如打印当前方法__func__, 对象,地址等等,所以项目最后每次运行调试控制台满满的都是打印日志,到release发布的时候,显然不太合适,这里其实可以用一个简单的宏来解决。

 #ifdef DEBUG

 #define DLog( s, ... ) NSLog( @"<%p %@:(%d)> %@", self, [[NSString stringWithUTF8String:__FILE__] lastPathComponent], __LINE__, [NSString stringWithFormat:(s), ##__VA_ARGS__] )//分别是方法地址,文件名,在文件的第几行,自定义输出内容

 #else

 #define DLog(...)

 #endif

注意在#else后,也就是release中一开始定义成NSLog(...)会报错: Implicit declaration of function 'DLog' is invalid in C99。

关于Debug下的Log打印问题

原因: Release版本下所定义的DLog就成了一个空函数,在链接的是时候会报错。

参考:  http://*.com/questions/29234725/implicit-declaration-of-function-dlog-is-invalid-in-c99