OSLog
使用示例
debug.log("===>111", ["id": 1, "name": "xiaoming"], ["id": 2, "name": "xiaoli"], type: .error)
debug.log("===>222", ["id": 111, "name": "xiaoli"], type: .debug)
debug.log("===>333", ["id": 222, "name": "xiaoli"])
debug.log("===>555\(["id": 222, "name": "xiaoli"])")
debug.log("===>666", [10, 9, 8, 7, 6])
debug.log("===>777", JSON([10, 9, 8, 7, 6]))
源码
import os.log
import OSLog
import SwiftyJSON
class debug {
/// 单例
static let shared: Logger = {
// 先定义instance为可选类型
var instance: Logger?
let queue = DispatchQueue(label: "com.oslog.singleton")
queue.sync {
// 在闭包内安全地初始化instance
instance = Logger(subsystem: Bundle.main.bundleIdentifier ?? "", category: "custom-os-log")
}
// 使用可选绑定确保instance有值后再返回,如果没有值会触发运行时错误,不过在正常逻辑下不会出现这种情况,因为闭包内会进行初始化
guard let unwrappedInstance = instance else {
fatalError("Singleton instance not initialized")
}
return unwrappedInstance
}()
/// 日志输出
/// - Parameters:
/// - items: 约定:当items只有一个对象时默认是打印数据,超过一个对象时默认第一个对象时标识符
/// items -> Examples
/// ========
/// debug.log([1, 2, 3, 4, 5])
/// debug.log("===>flag", ["id": 1, "name": "xiaoming"], ["id": 2, "name": "xiaoli"], type: .debug)
/// ========
/// - type: 类型,参考 OutputType
/// - file: 用于输出文件名称
/// - line: 用于输出代码行号
static func log(_ items: Any..., type: OSLogType = .debug, file: String = #file, line: Int = #line) {
//
let dateFormate = DateFormatter()
dateFormate.dateFormat = "yy-MM-dd HH:mm:ss.SSS"
let curT = Date()
let stringOfDate = dateFormate.string(from: curT)
//
var fileName = (file as NSString).lastPathComponent
fileName = fileName.replacingOccurrences(of: ".swift", with: "")
//
var logStr = "\(stringOfDate) \(fileName)【line:\(line)】"
let separator = "\n"
var raws = items
if items.count > 1 {
let first = "\(JSON(items[0]))"
logStr += first
logStr += separator
raws = Array(items.dropFirst())
} else {
logStr += separator
}
logStr += raws.map { "\(JSON($0))" }.joined(separator: separator)
shared.log(level: type, "\(logStr)")
}
}
FEATURED TAGS
iOS
OC
C
Xcode
MIMEType
屏幕旋转
Mac
工具
SQLite3
重命名
证书+内购
像素
pch
支付协议税务
APP转让
审核
银行卡格式化
git
描述文件
命令行
沙盒日志
i386
x86_64
控制台log
xcode10&iOS12
正则
textfield
输入限制
Pod
真机支持
封面尺寸
SDWebImage
Ruby
RVM
渐变色
jekyll
水印
富文本
标签
M3U8
动、静态库
异步上传
Url编码解码
AlertController
保活
pod报错
特定UI横竖屏
Launch版本号
ijkplayer
适配
手势
截图
网络和信号
礼物缓存
手绘礼物
UIPickerView
文件权限
键盘和菜单
耗时卡顿
国际化
Paypal
AWSS3
npm、Node
控制台
warning
扩展
防盗链
动画
分析
CallKit
侧滑
重置根控制器
播放器
裁剪
日志
bugly
uniapp
Swift
文字翻转
跨域
WebClip
网络请求
地图导航
ZSH
SPM
Vapor
导航
验证码
杀进程
Ubuntu
Android
JWT
vue
html-js
style-class
ssh
PHP
jks
css
Runtime
tree
uniCloud
圆角
总结
flex
block
图形验证码
gtm
share