我想执行2个请求并在结尾发送通知。我的代码检查一系列操作:
AFHTTPRequestOperation *operation1 = ...;
AFHTTPRequestOperation *operation2 = ...;
[operation1 setCompletionBlockWithSuccess:^(AFHTTPRequestOperation *operation, id responseObject) {
NSLog(@"asdf");
} failure:^(AFHTTPRequestOperation *operation, NSError *error) {
}];
[operation2 setCompletionBlockWithSuccess:^(AFHTTPRequestOperation *operation, id responseObject) {
NSLog(@"asdf");
} failure:^(AFHTTPRequestOperation *operation, NSError *error) {
}];
NSBlockOperation *operation3 = [NSBlockOperation blockOperationWithBlock:^{
NSLog(@"123");
}];
NSArray *operationArray = @[operation1, operation2, operation3];
for (int i = 1; i < operationArray.count; i++) {
NSOperation *op = operationArray[i];
[op addDependency:operationArray[i - 1]];
}
[queue addOperations:ops waitUntilFinished:NO];
我希望以下控制台日志:
asdf
asdf
123
但实际结果是:
asdf
123
asdf
为什么?
答案 0 :(得分:1)
来自文档
无法保证完成块的确切执行上下文,但通常是辅助线程。因此,您不应该使用此块来执行任何需要非常特定的执行上下文的工作。相反,您应该将该工作分流到应用程序的主线程或能够执行此操作的特定线程。例如,如果您有一个用于协调操作完成的自定义线程,则可以使用完成块来ping该线程。
即。不要依赖完成一个操作完成之后和另一个操作之前调用的完成块,因为不能保证这样做。