如果我在操作中取消NSInvocationOperation
是否正确?
例如:
.h文件:
//defined in the interface
NSInvocationOperation *op1;
NSOperationQueue *loadQueue;
.m文件:
-(id)init{
op1 = [NSInvocationOperation new];
loadQueue = [NSOperationQueue new];
}
-(void)downloadData{
op1 = [[NSInvocationOperation alloc] initWithTarget:self selector:@selector(loadServerResponse:) object:newerRequest];
[loadQueue addOperation:op1];
}
现在我有一种从服务器下载数据的方法。我添加了一个条件来检查是否有错误。如果是这样,我在方法中取消该操作,并在检索新的登录令牌时回调相同的方法。
- (void)loadServerResponse{
if(server_error){
[op1 cancel];
//fetch login token again
[self downloadData];
return;
}
我做错了吗?
答案 0 :(得分:1)
首先,引用op1
(我假设是类级别的ivar)是多个级别的Bad Thing™,第一个是NSOperationQueue将您的操作调度到后台线程,所以{{ 1}}将(最多)复制到该线程的上下文中,不再引用您尝试取消的原始操作。
考虑到您共享的逻辑,我认为您不必担心取消操作。您似乎特意想在取消后调用op1
,并且如果您先取消操作,则无法保证会发生这种情况。我只是删除取消操作的调用,然后继续。通常,您只能从外部源取消正在运行的操作(例如,如果您收到应用程序将进入后台状态的通知)。