sendAsynchronousRequest与drawView上的tableView reloadData延迟

时间:2011-11-17 15:30:20

标签: objective-c ios xcode ios5

我正在尝试使用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);

2 个答案:

答案 0 :(得分:16)

您需要在主线程上执行[tableView reloadData]。所有UI操作必须在主线程上完成。多种方法可以做到这一点。一个是:

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

编辑:将activityIndi​​cator添加到示例

答案 1 :(得分:3)

我在使用[[NSOperationQueue alloc] init]时遇到了一些问题,但使用[NSOperationQueue mainQueue]一切都很完美。使用新队列时,执行行不遵循自然序列