专注iOS开发iOS程序猿iOS Developer

iOS开发之自定义log

2016-11-24  本文已影响87人  论丶道

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


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

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

了解以上几点后我们就可以写代码了
在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来进行调试了~!

上一篇 下一篇

猜你喜欢

热点阅读