在生产中完全禁用XCGLogger中的日志

时间:2015-09-26 08:22:21

标签: ios swift logging xcglogger

如何在生产环境中完全禁用XCGLogger中的日志?

目前我正在使用logLevel = .None

这是推荐的方式吗?

1 个答案:

答案 0 :(得分:9)

这是一种可能的方式,但并不理想。

首先,我想知道你是否真的要完全禁用生产中的日志。使用errorsevere日志可以成为已发布应用的有用诊断工具。

如果你想完全消除生产中的日志,我建议改变你设置和使用记录器的方式,而不是我在官方文档中的方式。

将全局日志对象更改为可选:

let log: XCGLogger? = {
    #if DEBUG
        let log = XCGLogger.defaultInstance()
        log.setup(.Debug, showThreadName: true, showLogLevel: true, showFileNames: true, showLineNumbers: true, writeToFile: nil, fileLogLevel: .Debug)
        return log
    #else
        return nil
    #endif
}

然后将日志调用更改为:

log?.debug("whatever")

这将消除记录器的任何开销,因为log将在生产中nil,并且不会进行任何记录调用。