如何使用OSLog记录通用类型的值?

时间:2018-09-27 01:28:47

标签: swift logging

我有以下包装UserDefaults的方法,以便可以以类型安全的方式与API交互。

public func item<T>(forKey key: Key<T>) -> T? {
    var item: T?
    defer {
        #if DEBUG
        os_log(item != nil ? "Returned value for key '%@'" : "Returned 'nil' for key '%@'", log: Defaults.defaultsLog, type: .debug, key.value)
        #endif
    }
    if let value = defaults.value(forKey: key.value) as? T, value is FoundationCodable || value is SwiftCodable {
        item = value
        return value
    }
    guard let data = defaults.data(forKey: key.value) else { return nil }
    guard let decoded = try? decoder.decode(T.self, from: data) else { return nil }
    item = decoded
    return decoded
}

我想使用以下方法记录返回值:

func os_log(_ message: StaticString, dso: UnsafeRawPointer? = #dsohandle, log: OSLog = default, type: OSLogType = default, _ args: CVarArg...)

但是,我的通用类型T不符合CVarArg

是否可以记录返回值?如果是这样,那我该如何构造实现它的逻辑?

1 个答案:

答案 0 :(得分:1)

登录String(description:decoded) as NSString

相关问题