[MagicalRecord saveWithBlock:completion:]
在什么情况下会在完成 block 中显示 NO 成功并出现 nil 错误?
我见过的一种情况是保存 block 内的提取返回 nil,因此没有保存可做。但我看到保存 block 中的提取返回有效的托管对象。
示例代码:
[MagicalRecord saveWithBlock:^(NSManagedObjectContext *localContext) {
TransactionQueueItem *item = [self queueItemForToken:token context:localContext];
if (nil == item)
NSLog(@"item is nil for token %@", token);
item.lastTryDate = [NSDate date];
if (nil != errorMsg)
item.lastTryError = errorMsg;
}
completion:^(BOOL success, NSError *error) {
if (!success)
{
NSLog(@"Error %@ updating last Try time item for token %@", error, token);
}
else
{
if (nil != completionBlock)
completionBlock();
}
}];
我看到该项目恢复正常,但在保存时我得到成功 = NO 和错误 = nil,但我没有看到发生了什么。
Google/Bing 的各种搜索都没有得出结论性的结果。谢谢。
最佳答案
我遇到了同样的误解,但似乎成功
只是意味着它没有保存数据,而不是发生了错误。如果没有数据可保存,它不会返回成功,但您的数据仍然存在。
这是我在 success
到 NO
和 error
到 nil
之后得到的日志输出:
-08-01 14:07:01.003 TEST[39216:f03] -[NSManagedObjectContext(MagicalSaves) MR_saveWithOptions:completion:](0x8dbac50) → Saving <NSManagedObjectContext (0x8dbac50): *** UNNAMED ***> on *** BACKGROUND THREAD ***
2014-08-01 14:07:01.003 TEST[39216:f03] -[NSManagedObjectContext(MagicalSaves) MR_saveWithOptions:completion:](0x8dbac50) → Save Parents? 1
2014-08-01 14:07:01.004 TEST[39216:f03] -[NSManagedObjectContext(MagicalSaves) MR_saveWithOptions:completion:](0x8dbac50) → Save Synchronously? 0
2014-08-01 14:07:01.004 TEST[39216:f03] -[NSManagedObjectContext(MagicalSaves) MR_saveWithOptions:completion:](0x8db99c0) NO CHANGES IN ** BACKGROUND SAVING (ROOT) ** CONTEXT - NOT SAVING
在 NSManagedObjectContext+MagicalSave.m:41
文件中,您会看到它会检查当前上下文中的更改,但如果没有新数据则不会保存它:
if (![self hasChanges]) {
MRLog(@"NO CHANGES IN ** %@ ** CONTEXT - NOT SAVING", [self MR_workingName]);
if (completion)
{
dispatch_async(dispatch_get_main_queue(), ^{
completion(NO, nil);
});
}
return;
}
关于iOS:[MagicalRecord saveWithBlock:completion:] 的成功条件为 NO,错误为 nil,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23397815/