从网站异步加载数据时出现延迟

时间:2013-01-31 16:21:33

标签: objective-c asynchronous

我写了一个应用程序,将网站中的数据解析为tableview。

我希望应用程序在完成下载数据并将其显示到表视图之前阻止UI,因此我使用MBProgressHUD在解析发生时为用户显示反馈。

我编写了以下方法来异步下载数据:

- (void)getDataFromUrlString:(NSString *)string
{
   NSDate *dateAtStartOfGetDataFromString = [[NSDate alloc] initWithTimeIntervalSinceNow:0];
   NSLog(@"dateAtStartOfGetDataFromString = %@", dateAtStartOfGetDataFromString);

   NSMutableString *databaseURL = [[NSMutableString alloc] initWithString:string];

   NSURL *url = [NSURL URLWithString:databaseURL];

   NSURLRequest *request = [NSURLRequest requestWithURL:url];
   NSOperationQueue *queue = [[NSOperationQueue alloc] init];

   [NSURLConnection sendAsynchronousRequest:request queue:queue completionHandler:^(NSURLResponse *response, NSData *data, NSError *error)
   {
     if ([data length] > 0 && error == nil){
        [self loadReports:data];
     }else if ([data length] == 0 && error == nil){

     }else if (error != nil && error.code == NSURLErrorTimedOut){ //used this   NSURLErrorTimedOut from foundation error responses

     }else if (error != nil){

     }
 }];
 NSDate *dateAtEndOfGetDataFromString = [[NSDate alloc] initWithTimeIntervalSinceNow:0];
 NSLog(@"dateAtEndOfGetDataFromString = %@", dateAtEndOfGetDataFromString);

}

这是loadReports:方法:

- (void)loadReports:(NSData *)data {
    //...Get the data into the table view data array

    [HUD hide:YES];
    _reports = newReports;

    [self.tableView reloadData];
    NSDate *dateAfterLoadReports = [[NSDate alloc] initWithTimeIntervalSinceNow:0];
    NSLog(@"dateAfterLoadReports = %@", dateAfterLoadReports);
}

应用程序加载非常快并显示HUD,直到将数据加载到表视图成功完成。

问题是在数据显示之前需要花费太长时间(5秒)。

我检查了应用程序使用NSDate加载和解析数据的时间:

2013-01-31 18:06:52.508 TrafficReport[4472:c07] dateAtStartViewDidLoad = 2013-01-31 16:06:52 +0000
2013-01-31 18:06:52.513 TrafficReport[4472:c07] dateAtStartOfGetDataFromString = 2013-01-31 16:06:52  +0000
2013-01-31 18:06:52.513 TrafficReport[4472:c07] dateAtEndOfGetDataFromString = 2013-01-31 16:06:52 +0000
2013-01-31 18:06:52.516 TrafficReport[4472:c07] dateAtEndViewDidLoad = 2013-01-31 16:06:52 +0000
2013-01-31 18:06:52.664 TrafficReport[4472:4a03] dateAfterLoadReports = 2013-01-31 **16:06:52** +0000
2013-01-31 18:06:57.569 TrafficReport[4472:4a03] dateAtStartCellForRow = 2013-01-31 **16:06:57** +0000

正如你在loadReports之后看到的那样,在执行cellForRow方法之前有5秒的延迟,我不知道它是什么以及如何解决它。

有什么想法吗?

1 个答案:

答案 0 :(得分:2)

您必须在主线程中执行所有UI更改:

....
if ([data length] > 0 && error == nil){
    dispatch_async(dispatch_get_main_queue(), ^{
        [self loadReports:data];
    });
}
....