2

私のコードでは、これを呼び出しています

[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がリリースされていないためですか、それともその行に何かありますか?

4

2 に答える 2

4

あなたのコードからは、リクエストのハンドラ ブロックがどのスレッドで呼び出されているかわかりませんが、それがメイン スレッドでない場合、それが問題になる可能性があります。

内からラベルのテキスト プロパティを設定してみてください

dispatch_async(main, ^{
    _label.text = [dict objectForKey:@"text"];
});

ブロック。

于 2013-02-04T23:12:32.390 に答える