小编dpi*_*uto的帖子

NSBlockOperation,NSOperationQueue和Blocks

我必须从RestAPI中同步一堆信息.我必须做6次RestAPI调用才能完成工作.我用Blocks设计了API调用,如果有的话,返回NSError.这些调用中的3个应该执行嵌套,因为第一个调用向其他调用提供信息并允许执行,而其他3个调用可以独立运行.由于提高了网络性能,我将同步调用设计如下:

  • 1个NSBlockOperation,包含第一个嵌套的3个块;
  • 1个包含其他三个块的NSBlockOperation;
  • 1 NSBlockOperation,我用作"semphore",并告诉我完成所有工作.

最后一个NSBlockOperation依赖于前两个NSBlockOperation.

我还有一个NSOperationQueue,它包含所有三个NSBlockOperation,其中信号量NSBlockOperation作为队列中的最后一个添加.我要实现的结果是:前两个块名为Concurrently,当它们的工作完成时,调用信号量NSBlockOperation并将控件返回给提供UIAlertMessage的用户.

结果不是之前解释的:返回控件而不等待syncAllBlocksInformation块的结束.

在包含NSBlockOperation的代码下面:

-(void)syncAllBlocksInformation:(void(^)(NSError *error))completion{

__block NSError *blockError = nil;

NSOperation *syncUserInfoOperation = [NSBlockOperation blockOperationWithBlock:^{
    [dataSync syncUserInfo:tfMail.text password:tfPassword.text completion:^(NSError *error, NSNumber *idUser) {
        if(!error){
            [dataSync syncUserfilesInfo:idUser completion:^(NSError *error) {
                if(!error){
                    [dataSync syncUserBookings:^(NSError *error) {
                        if(error){
                            blockError = error;
                        }
                    }];
                }
                else{
                    blockError = error;
                }
            }];

        }
        else{
            blockError = error;
        }
    }];
}];



NSBlockOperation *otherSyncOperations = [NSBlockOperation blockOperationWithBlock:^{
    [dataSync syncNewsInfo:^(NSError *error) {
        if(error){
            blockError = error;
            NSLog(@"error %@",error);
        }
    }]; …
Run Code Online (Sandbox Code Playgroud)

objective-c nsoperationqueue ios objective-c-blocks nsblockoperation

5
推荐指数
1
解决办法
1727
查看次数