私のコードでは、これを呼び出しています
[request performRequestWithHandler:^(NSData *responseData, NSHTTPURLResponse *urlResponse, NSError *error) {
if (responseData != nil) {
NSError *error = nil;
NSArray *dataSource = [NSJSONSerialization JSONObjectWithData:responseData options:NSJSONReadingMutableLeaves error:&error];
[self.ticker1 loadData:dataSource];
} else {
NSLog(@"Error requesting timeline %@ with user info %@.", error, error.userInfo);
}
}];
そして、loadData:
私がこれを行う方法で
NSDictionary *dict = [dataSource objectAtIndex:0];
_label.text = [dict objectForKey:@"text"];
dispatch_queue_t queue = dispatch_queue_create("com.test.ios.task", NULL);
dispatch_queue_t main = dispatch_get_main_queue();
dispatch_async(queue, ^{
NSURL *imageURL = [NSURL URLWithString:[[dict objectForKey:@"user"] objectForKey:@"profile_image_url"]];
NSData *imageData = [NSData dataWithContentsOfURL:imageURL];
dispatch_async(main, ^{
_image.image = [UIImage imageWithData:imageData];
});
});
dispatch_release(queue);
問題は、メイン キューにロードするイメージが、_label.text
設定されているよりもずっと速くロードされることです。約 4 ~ 5 秒の長い遅延の後に設定されます。なぜこれが起こっているのか知りたいです。main queue
がリリースされていないためですか、それともその行に何かありますか?