objective-c – sendAsynchronousRequest,绘制时带有tableView reloadData延迟

objective-c – sendAsynchronousRequest,绘制时带有tableView reloadData延迟,第1张

概述我正在尝试使用iOS5中添加的新sendAsynchronousRequest. 我有一个模型类(File),其中一个方法从服务器请求一些数据,然后将此数据传递给创建模型对象的控制器类(FilesController). 模型类有一个方法,下一个代码: [NSURLConnection sendAsynchronousRequest:request queue:[[NSOperationQueue 我正在尝试使用iOS5中添加的新sendAsynchronousRequest.
我有一个模型类(file),其中一个方法从服务器请求一些数据,然后将此数据传递给创建模型对象的控制器类(filesController).

模型类有一个方法,下一个代码:

[NSURLConnection sendAsynchronousRequest:request queue:[[NSOperationQueue alloc] init] completionHandler:^(NSURLResponse *response,NSData *data,NSError *error) {    NSArray *decodedResponse = [NSJsONSerialization JsONObjectWithData:data options:NSJsONReadingMutableContainers error:nil];    NSArray *files = [self _dictionarIEsTofiles:decodedResponse];    handler(files);}];

控制器类,使用它如下:

[file findAll:conditions completionHandler:^(NSArray *files) {    dataSource = files;    NSLog(@"set");    [self.tableVIEw reloadData];    NSLog(@"reload");    activityIndicator.hIDden = TRUE;}];

在控制台中,我可以立即查看NSLogs如何显示“设置”和“重新加载”消息,但表和指示器在几秒(5-10s)过去之前不会改变.

有人知道问题出在哪里?

谢谢.

PD:我用兼容的同步更改了异步请求,然后问题消失了,但是想要使用异步请求.

这是兼容的同步代码:

NSData *responseData = [NSURLConnection sendSynchronousRequest:request returningResponse:nil error:nil];NSArray *decodedResponse = [NSJsONSerialization JsONObjectWithData:responseData options:NSJsONReadingMutableContainers error:nil];NSArray *files = [self _dictionarIEsTofiles:decodedResponse];handler(files);
解决方法 你需要在主线程上做[tableVIEw reloadData].所有UI *** 作必须在主线程上完成.多种方法可以做到这一点.一个是:

dispatch_async(dispatch_get_main_queue(),^{    [self.tableVIEw reloadData];    activityIndicator.hIDden = TRUE;});

编辑:添加activityIndi​​cator示例

总结

以上是内存溢出为你收集整理的objective-c – sendAsynchronousRequest,绘制带有tableView reloadData延迟全部内容,希望文章能够帮你解决objective-c – sendAsynchronousRequest,绘制时带有tableView reloadData延迟所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址:https://www.54852.com/web/1054214.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-05-25
下一篇2022-05-25

发表评论

登录后才能评论

评论列表(0条)

    保存