我正在开发一个通过NSURLSession调用api的应用程序。当Api正确工作时,没有问题,但是当由于任何错误而没有接收到数据时,在序列化之后,它会抛出错误,但是它的else块永远不会被调用。
let task = session.dataTaskWithRequest(request) { (let data, let response, let error) in
do {
guard let data:NSData = data , let response: NSURLResponse = response where error == nil else {
throw error!
}
guard let json = try NSJSONSerialization.JSONObjectWithData(data, options: []) as? NSDictionary else{
print("Serialization failed") //This block never executes even if the Serialization Fails
throw JSONError.ConversionFailed
}
guard json.valueForKey("success") != nil else {
return
}
self.apidata = json
dispatch_async(dispatch_get_main_queue()){
self.tableView.reloadData()
}
print(json.valueForKey("success")!)
}
catch let error as JSONError{
self.showalertview(error.rawValue)
print(error.rawValue)
} catch let error as NSError{
print(error.debugDescription)
}
}
task.resume()我在这里做错什么了?
发布于 2016-07-29 08:03:03
考虑:
do {
guard let json = try NSJSONSerialization.JSONObjectWithData(data, options: []) as? NSDictionary else {
// A
}
} catch {
// B
}如果NSJSONSerialization抛出一个错误(也就是说,如果它不是真正的JSON响应或响应格式错误),它将直接转到B,并且guard语句不会起作用。只有当(A) guard调用本身没有抛出任何错误(即JSON格式良好)时,A语句才会执行JSON;但是(b)对字典的强制转换失败(例如,顶级JSON对象是数组而不是字典)。这是一个极不可能的场景(您的服务器必须意外地返回一个格式良好的JSON响应,它不是字典,例如JSON数组)。
为了实现您想要的结果,您可以使用try?来确保NSJSONSerialization不会抛出任何错误:
do {
guard let json = try? NSJSONSerialization.JSONObjectWithData(data, options: []) as? NSDictionary else {
// A
throw JSONError.ConversionFailed
}
} catch {
// B
}通过这样做,只有当A执行throw时,才会调用B
https://stackoverflow.com/questions/38651941
复制相似问题