iOS开发之自定义log

作者: 论丶道 | 来源:发表于2016-11-24 00:24 被阅读87次

    在我们日常开发中,打印输出作为调试手段还是占据相当大的一个比重的.但是打印又非常消耗性能,我们仅仅希望在调试阶段使用,等到程序发布阶段时又需要将所有打印全部撤销或者注释掉,在OC代码中我们可以通过宏定义来解决这个,但是swift不支持宏定义,我们该怎么解决呢?


    • 自定义log
    ![](http:https://img.haomeiwen.com/i1481063/b1eaeac02923a3e6.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

    如上图所示,当我们调用自定义的打印方法时,控制台输出的信息相当明确,有打印所在的,所在的function以及所在的行号.
    要想达到上述目的,github上有一款框架可以做到--->QorumLogs

    • 下载地址: https://github.com/goktugyil/QorumLogs
      但是今天要讲的是自定义,下面就来带大家自定义一个log
      首先要明确几点:
      • 在swift中,__FILE__就是包含这个符号的文件路径
      • __FUNCTION__是包含这个符号的方法名字
      • __LINE__是符号出现所在的行号
        注意 :  在swift3.0中,以上几个符号分别更换为#file,#function,#line
        

    了解以上几点后我们就可以写代码了
    在AppDelegate中实现func

      func ZDLog<T>(message : T,file : String = #file,method : String = #function,line : Int = #line) {
            
            #if ZD_DEBUG
            
                //处理文件名
            let fileName = (file as NSString).pathComponents.last!
                
            print("\(fileName)-\(method)[\(line)]-\(message)")
                
            #endif
        }
    

    自定义完log后我们就需要处理debug以及release状态下的log了,由于之前说到swift不支持宏定义,但是swift中有自定义flag

    如上图所示,点击工程-Build Setting-->Custom flag-->在Other Swift Flags中添加-D ZD_DEBUG自定义的flag就ok了! 做完这些就可以在开发阶段无忧无虑地使用log来进行调试了~!

    相关文章

      网友评论

        本文标题:iOS开发之自定义log

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