closeWithCompletionHandler"
的文档说:"保存操作结束后,将执行 completionHandler 中的代码。"但是,在我的应用程序中,这段代码:
NSLog(@"closeWithCompletionHandler");
[self.document closeWithCompletionHandler:^(BOOL success) {
if (success) {
NSLog(@"completionHandler");
...
立即执行(在 iOS6.1 上):
2013-07-18 19:43:12.673 FooBar[819:907] closeWithCompletionHandler
2013-07-18 19:43:12.675 FooBar[819:907] completionHandler <-- look here
2013-07-18 19:43:16.234 FooBar[819:907] encoded
即使实际将数据写入文件需要几秒钟(我通过跟踪 contentsForType:error:
知道这一点)。
contentsForType:error:
实现如下所示:
- (id)contentsForType:(NSString *)typeName error:(NSError *__autoreleasing *)outError
{
NSMutableDictionary* wrappers = [NSMutableDictionary dictionary];
[self encodeObject:self.data toWrappers:wrappers preferredFilename:kDocumentDataPath];
NSFileWrapper* fileWrapper = [[NSFileWrapper alloc] initDirectoryWithFileWrappers:wrappers];
NSLog("encoded");
return fileWrapper;
}
请注意编码在 completionHandler 执行后很长时间内完成:
2013-07-18 19:43:12.675 FooBar[819:907] completionHandler
2013-07-18 19:43:16.234 FooBar[819:907] encoded <-- look here
为什么会这样?我应该如何确保在继续之前将数据写入文件?
最佳答案
我相信你想寻找成功的值(value)是真实的,所以你的代码可能看起来像这样
“我应该如何确保在继续之前将数据写入文件?”
完成处理程序: 保存并关闭操作结束后要执行的代码块。该 block 不返回任何值,只有一个参数: 成功 如果任何保存操作成功则为 YES,否则为 NO。
回答:
NSLog(@"closeWithCompletionHandler");
[self.document closeWithCompletionHandler:^(BOOL success) {
if(success){
NSLog(@"completionHandler");
}
“为什么会这样?”
有多种原因,一个可能是因为写入失败并且正在回滚,另一个可能是 iOS 的额外操作系统开销。最后可能是您只是错误地读取了时间长度。
关于ios - UIDocument closeWithCompletionHandler : completes immediately,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17730624/