在我们日常开发中,打印输出作为调试手段还是占据相当大的一个比重的.但是打印又非常消耗性能,我们仅仅希望在调试阶段使用,等到程序发布阶段时又需要将所有打印全部撤销或者注释掉,在OC代码中我们可以通过宏定义来解决这个,但是swift不支持宏定义,我们该怎么解决呢?
- 自定义log
如上图所示,当我们调用自定义的打印方法时,控制台输出的信息相当明确,有打印所在的类
,所在的function
以及所在的行号
.
要想达到上述目的,github上有一款框架可以做到--->QorumLogs
- 下载地址: https://github.com/goktugyil/QorumLogs
但是今天要讲的是自定义,下面就来带大家自定义一个log
首先要明确几点:- 在swift中,
__FILE__
就是包含这个符号的文件路径 -
__FUNCTION__
是包含这个符号的方法名字 -
__LINE__
是符号出现所在的行号注意 : 在swift3.0中,以上几个符号分别更换为#file,#function,#line
- 在swift中,
了解以上几点后我们就可以写代码了
在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来进行调试了~!