swift中自定义Log,iOS开发之自定义log

日期:2019-09-15编辑作者:编程应用

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

swift中自定义log输出日志,swift支持全局函数,不写在任何类中的方法可以当做全局方法使用。这里写在了Appdelegate.swift文件中:

  • 自定义log
func toolLog<T>(message : T,file: String = #file, funcName: String = #function, lineNum : Int = #line) {
    #if DEBUG
    // let fileName = (file as String);
    print("函数:(funcName)-行:(lineNum)-(message)");
    #endif
}

图片 1![]()

因为在swift中没有宏定义的概念,添加截图所示

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

图片 2

  • 下载地址: :

    • 在swift中,__FILE__就是包含这个符号的文件路径
    • __FUNCTION__是包含这个符号的方法名字
    • __LINE__是符号出现所在的行号

      注意 : 在swift3.0中,以上几个符号分别更换为#file,#function,#line
      

image.png

了解以上几点后我们就可以写代码了在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("-[]-") #endif }

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

图片 3

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

本文由今晚最快开奖现场直播发布于编程应用,转载请注明出处:swift中自定义Log,iOS开发之自定义log

关键词:

浅析饿了么,仿抖音下拉刷新

难度:⭐️⭐️效果: 话不多说,先上DEMO记得star哦 下拉刷新 下拉进入活动会场 效果图 饿了么App在最近版本上线了...

详细>>

Masonry简单使用,Masonry介绍与使用实践

1)Masonry是一个轻量级的布局框架,拥有自己的描述语法,采用更优雅的 链式语法 封装自动布局,简洁明了并具有...

详细>>

增加和删除改查

一.文章概要 当前使用工具是XCode7. 这篇文章主要是写了对于基本数据类型的"增删改查"的操作,至于特殊类型比如UII...

详细>>

面向公约开采笔记,Swift编制程序最佳体验之Ge

关于Swift代码风格,能让绝大部分人的眼前一亮,WTF?还能这样写?今天就带来一段Swift常见的Generic 比如 UIButton,U...

详细>>