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