zoukankan      html  css  js  c++  java
  • 不直接用NSLog

    公司中不直接使用NSLog,而是利用宏定义自己的打印函数,将该打印函数写在项目的.pch文件中.调试的时候往往用到好多打印,但发布的时候确不需要.(一下是在公司中的一些处理)

    一,固定写法:

            #define  MYLog(...)  NSLog(__VA_ARGS__)

    二,注意:

            1,MYLog括号中的...是固定写法,表示可以接受任意多个参数.

            2,NSLog括号中的__VA_ARGS__  也是固定写法,前后用了两个下划线

    三,使用方式:

            项目中Supporting files文件夹下有个 "工程名-Prefix.pch"文件,你可以在该文件下声明

            #define  MYLog(...)  NSLog(__VA_ARGS__)

            这样之后工程中的任何一个文件中都可以使用改自定的打印函数(也就是说可以在该.pch中放一些全局的东西)

    四,好处:

            这样使用的好处就是,项目调试期间,我们可能会用到好多MYLog()函数打印.

            如果不需要时,只需将.pch中该宏修改为:(这样就相当于MYLog()代表的是注释了)

            #define  MYLog(...)  //NSLog(__VA_ARGS__)    

    五,修改:(这样做还不够智能,每次调试的时候需要用到打印,发布的时候不需要打印还要手动修改一下)  

            其实系统提供了一个宏  DEBUG 表示在调试状态下

            因为上述代码可以优化为:    (下述代码是公司常用代码)

    1
    2
    3
    4
    5
    #ifdef DEBUG  //调试阶段
    #define MYLog(...)  NSLog(__VA_ARGS__)
    #else //发布阶段
    #define MYLog(...)
    #endif

                     

  • 相关阅读:
    java编程题古典算法之兔子问题
    java基础之final关键字
    java基础之final关键字
    java基础之静态代码块,局部代码块,构造代码块区别。
    java基础之静态代码块,局部代码块,构造代码块区别。
    java基础之完数判断
    java基础之完数判断
    java基础之二维数组不定义列数
    正则表达式快速入门
    深入理解JSON对象
  • 原文地址:https://www.cnblogs.com/wvqusrtg/p/5291060.html
Copyright © 2011-2022 走看看