我在我的应用中使用NSURLSession
,如下所示:
func wsQAshowTag(tag: Int, completion: ([AnyObject]! -> Void)) {
let requestString = NSString(format: “URL”, tag) as String
let url: NSURL! = NSURL(string: requestString)
let task = NSURLSession.sharedSession().dataTaskWithURL(url, completionHandler: {
data, response, error in
do {
let result = try NSJSONSerialization.JSONObjectWithData(data!, options: NSJSONReadingOptions.AllowFragments) as! [AnyObject]
completion(result)
}
catch {
completion(nil)
}
})
task.resume()
}
这可以按预期工作,但我发现它非常慢,当我使用NSURLConnection
时我发现它非常快(这是使用相同的URL)为什么NSURLSession
非常慢NSURLConnection
非常快?是否有加速NSURLSession
?
以下是我如何称呼它:
self.wsQAshowTag(Int(barcode)!, completion: { wsQAshowTagArray in
//Code Here
})
答案 0 :(得分:7)
您需要将UI更新发送到主队列。如果更新它而不将其发送到主队列,则更新数据可能需要很长时间。
由于我们正在解析JSON,您还需要打包completion(result)
。
代码抓取存储的完成处理程序并在主线程上调用它。
func wsQAshowTag(tag: Int, completion: ([AnyObject]! -> Void)) {
let requestString = NSString(format: "URL", tag) as String
let url: NSURL! = NSURL(string: requestString)
let task = NSURLSession.sharedSession().dataTaskWithURL(url, completionHandler: {
data, response, error in
do {
let result = try NSJSONSerialization.JSONObjectWithData(data!, options: NSJSONReadingOptions.AllowFragments) as! [AnyObject]
dispatch_async(dispatch_get_main_queue()) {
completion(result)
}
} catch {
dispatch_async(dispatch_get_main_queue()) {
completion(nil)
}
print("error serializing JSON: \(error)")
}
})
task.resume()
}
答案 1 :(得分:0)
你应该添加
dispatch_async(dispatch_get_main_queue()) {
...
}
如果completion(...)
处理程序更改了UI状态(通常是这样),则每个completion
附近。
在后台队列上调用URL Session的完成处理程序,并且从后台线程更改UI是错误的,并且通常会创建长暂停。
这与NSURLConnection
不同,::
总是在已经启动连接的线程上调用委托方法,即通常是主线程。
例如参见this tutorial。