Swift-优雅的打印Log

iOS开发中Log打印是最为常见的调试方式,没有之一.
Swift提供了两种打印方式

public func print(_ items: Any..., separator: String = default, terminator: String = default)

public func debugPrint(_ items: Any..., separator: String = default, terminator: String = default)

debugPrint可以自己识别是否是release环境,如果是release环境就不会打印
虽然Swift贴心的提供了debugPrint这个方法,但是对于Log太多的项目来说,找到自己的打印信息还是费点眼睛的.
如果打印出时间,文件,方法那么就更好了
废话不多说,直接上代码
首先需要在Build Setting -> Other Swift Flags设置一下

屏幕快照.png
public func OKPrint( _ object: @autoclosure() -> Any?,
                     _ file: String = #file,
                     _ function: String = #function,
                     _ line: Int = #line) {
    #if DEBUG
        guard let value = object() else {
            return
        }
        var stringRepresentation: String?
        
        if let value = value as? CustomDebugStringConvertible {
            stringRepresentation = value.debugDescription
        }
        else if let value = value as? CustomStringConvertible {
            stringRepresentation = value.description
        }
        else {
            fatalError("gLog only works for values that conform to CustomDebugStringConvertible or CustomStringConvertible")
        }
        
        let gFormatter = DateFormatter()
        gFormatter.dateFormat = "HH:mm:ss:SSS"
        let timestamp = gFormatter.string(from: Date())
        let queue = Thread.isMainThread ? "UI" : "BG"
        let fileURL = NSURL(string: file)?.lastPathComponent ?? "Unknown file"
        
        if let string = stringRepresentation {
            print("✅ \(timestamp) {\(queue)} \(fileURL) > \(function)[\(line)]: \(string)")
        } else {
            print("✅ \(timestamp) {\(queue)} \(fileURL) > \(function)[\(line)]: \(value)")
        }
    #endif
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,267评论 4 61
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,087评论 19 139
  • 不想总是被负面情绪包围,但生活中总会有些不顺心的事,无可避免。 升入大学后,好多事情都不再有人手把手的教着,必须得...
    刘锦年阅读 443评论 4 1
  • 何以飘零去, 何以少团栾。 何以离别久, 何以不得安。
    倾一生白了头阅读 463评论 0 2
  • 真正的好朋友大概就是“永远都不会想起,永远也不会忘记。” 上大学之前...
    夏煦阅读 135评论 0 0