我想执行两个请求,并在最后发送一个通知。我检查操作序列的代码:
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为什么?
发布于 2014-11-12 19:44:41
从医生那里
未保证完成块的确切执行上下文,但通常是次要线程。因此,您不应该使用这个块来执行任何需要非常特定的执行上下文的工作。相反,您应该将该工作分流到应用程序的主线程或能够执行该工作的特定线程。例如,如果您有一个自定义线程来协调操作的完成,则可以使用完成块来ping该线程。
也就是说,不要依赖于在一个操作完成后和另一个操作开始之前调用的完成块,因为它不一定会像那样发生。
https://stackoverflow.com/questions/26895105
复制相似问题