1

文档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;
}

请注意在完成处理程序执行后很长时间编码完成:

2013-07-18 19:43:12.675 FooBar[819:907] completionHandler
2013-07-18 19:43:16.234 FooBar[819:907] encoded <-- look here

为什么会这样?在继续之前,我应该如何确保将数据写入文件?

4

1 回答 1

1

我相信你想寻找成功的价值是真实的,所以你的代码可能看起来像这样

“我应该如何确保在继续之前将数据写入文件?”

completionHandler:保存并关闭操作结束后要执行的代码块。该块不返回任何值,只有一个参数: 如果任何保存操作成功,则成功为 YES,否则为 NO。

http://developer.apple.com/library/ios/#documentation/UIKit/Reference/UIDocument_Class/UIDocument/UIDocument.html#//apple_ref/occ/instm/UIDocument/closeWithCompletionHandler

回答:

NSLog(@"closeWithCompletionHandler");
[self.document closeWithCompletionHandler:^(BOOL success) {
     if(success){   
         NSLog(@"completionHandler");
     }

“为什么会这样?”

许多原因,一个可能是因为写入失败并且它正在回滚,另一个可能是 iOS 的额外操作系统开销。最后可能是您只是阅读错误的时间长度。

于 2013-07-18T18:19:33.557 回答