美文网首页
项目中的NSLog

项目中的NSLog

作者: Baby小猪 | 来源:发表于2016-05-04 12:14 被阅读60次

           在项目的过程中,经常遇到要在调试的时候打印log,但是上线或是release 的时候不需要去显示log 的情况,此时你辛辛苦苦写了那么多的log,你要么就手动注释掉,要么就是设一个开关变量,企图用这个总开关开启。其实可以充分利用宏定义进行设置

           步骤比较简单,只需要 在ProjectName_Prefix.pch 中追加你对应的宏定义,不用import 就可以直接使用了。

    宏定义写法如下:

    #ifdef DEBUG

    #define LOG(...) NSLog(__VA_ARGS__);

    #define LOG(...) NSLog(@"%s Line %d: \n %@ \n\n", __func__, __LINE__, [NSString stringWithFormat:__VA_ARGS__])

    #else

    #define LOG(...); 

    #define LOG_METHOD;

    #endif

    这样设置后,只需要在Product ->Scheme->Edit Scheme ->info选择,是release ,还是debug版本即可。如果debug 版本,则答应log,若release版本则不打印。

    我们发布到appstore 上的版本均是release版本,这里简单说下这两个版本的差异。

    release 是发行版本,比debug版本要小一些,他们调用两个不同底层库,debug 包含的信息多,可以断点调试,单步执行,使用使用TRACE/ASSERT等调试输出语句,

    但是release 版本不包含调试信息,运行速度比较快。

    另外在此处设置的DEBUG 参数可以在下面的路径进行设置:工程->Target->Build Setting ->Preprocessor Macros。默认系统已经给出了DEBUG的参数。如果要增加新的参数,则在哪里进行增加。

    相关文章

      网友评论

          本文标题:项目中的NSLog

          本文链接:https://www.haomeiwen.com/subject/mwmrrttx.html