我目前正在像这样解析 JSON
struct ExampleStruct : Codable {
init() {
}
// implementation
}
if let jsonData = jsonString.data(using: .utf8) {
do {
let decoder = JSONDecoder()
let object = try decoder.decode(ExampleStruct.self, from: jsonData)
} catch {
print("Coding error - \(error)")
}
}
这很好用,但是我周末一直在努力学习泛型。我正在尝试编写一个方法,传入一个 Codable 结构类型和一个 JSON 字符串,该字符串返回我想要返回的类型的对象。
我已经尝试过以下操作:-
func getType<T>(_ anyType: T.Type, from jsonString:String) -> T? {
if let jsonData = jsonString.data(using: .utf8) {
do {
let decoder = JSONDecoder()
let object = try decoder.decode(anyType, from: jsonData)//Errors here
return object as? T
return nil
} catch {
print("Coding error - \(error)")
return nil
}
}
return nil
}
然后当我想做上述事情时
if let exampleStruct:ExampleStruct = getType(type(of: ExampleStruct()), from: jsonString) {
print(exampleStruct)
}
但是在 let = object 行上我收到以下错误
无法转换类型“T”的值(全局函数“getType(的通用参数)”:from:)') 到预期的参数类型 'T' (实例方法 'decode( 的通用参数):从:)')
and
在参数类型“T.Type”中,“T”不符合预期类型“Decodable”
正如我所说,这个周末我一直在尝试学习泛型,但我的理解显然遇到了障碍。有没有解决这个问题的方法,这确实是我正在尝试做的事情,甚至是可能的或者是一个好主意?
首先,强烈建议交出一个错误throw
ing 函数给调用者。
其次Data
从 UTF8 字符串创建永远不会失败。
您必须将泛型类型限制为Decodable
,不需要将类型作为额外参数传递。
你的函数可以简化为
func getType<T : Decodable>(from jsonString:String) throws -> T {
let jsonData = Data(jsonString.utf8)
return try JSONDecoder().decode(T.self, from: jsonData)
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)