我在我的应用程序中使用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
})发布于 2016-07-16 06:14:38
您需要将UI更新发送到主队列。如果不将其发送到主队列,则更新数据可能需要很长时间。
您还需要包装completion(result),因为我们正在解析JSON。
代码捕获存储的完成处理程序并在主线程.上调用它。
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()
}发布于 2016-07-15 18:32:08
你应该加上
dispatch_async(dispatch_get_main_queue()) {
...
}如果completion(...)处理程序更改UI状态(通常是这样的),则围绕每个completion。
在后台队列上调用URL会话的完成处理程序,从后台线程更改UI是错误的,通常会造成长时间的暂停。
这与NSURLConnection不同,后者总是在启动连接的线程(通常是主线程)上调用委托方法。
例如,在本教程中见。
https://stackoverflow.com/questions/37450763
复制相似问题