8

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

目前我正在使用logLevel = .None.

这是推荐的方式吗?

4

1 回答 1

9

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

首先,我想知道您是否真的想在生产中完全禁用日志。usingerrorseverelogs 可以作为已发布应用程序的有用诊断工具。

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

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

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在生产中并且永远不会进行记录调用。

于 2015-09-27T02:01:47.477 回答