1

我正在发送一个异步 http GET 请求,并且正在正确调用 completionHandler。像 NSLog 这样的回调中的代码会运行,因为我可以在日志中看到输出。但是,以下行: self.imageView.image = nil; 似乎直到 NSLog 语句“到达这里”几秒钟后才生效。有谁知道发生了什么?示例代码如下:

在 ViewController.m 中:

@interface ViewController ()
@property (weak, nonatomic) IBOutlet UIImageView *imageView;
@end

@implementation ViewController
@synthesize imageView = _imageView;

-void viewDidLoad {
    // ImageView
    UIImage *image = [UIImage imageNamed:@"test.jpg"];
    self.imageView.backgroundColor = [UIColor blackColor];
    self.imageView.clipsToBounds = YES;
    self.imageView.image = image;
}

-void test {

    NSMutableURLRequest *request = [NSMutableURLRequest requestWithURL:[NSURL URLWithString:@"http://someurl"] cachePolicy:NSURLRequestReloadIgnoringLocalAndRemoteCacheData timeoutInterval:10];
    [request setHTTPMethod:@"GET"];
    NSOperationQueue *queue = [[NSOperationQueue alloc] init];
    [NSURLConnection sendAsynchronousRequest:request queue:queue
completionHandler:^(NSURLResponse *response, NSData *data, NSError *error) {
        self.imageView.image = nil;
        NSLog(@"got here");
    }];
}

@结尾

4

2 回答 2

3

啊,看起来像将队列参数设置为 [NSOperationQueue mainQueue] 固定,因为它在这里:

NSURLConnection sendAsynchronousRequest:queue:completionHandler:连续发出多个请求?

于 2013-02-27T08:40:59.303 回答
3

正如 Undept 建议的那样,在主线程上调用这些行。像这样:

dispatch_async (dispatch_get_main_queue (),  ^{
self.imageView2.image = nil;
self.imageView.image = nil;
}); 
于 2013-02-27T08:41:58.837 回答