尝试关闭UIDocument时防止崩溃

时间:2012-07-06 14:32:11

标签: objective-c ios icloud uidocument

我想知道如何在尝试关闭两次UIDoc时防止崩溃。我试图在我的代码中确保你(理论上)不能两次关闭UIDocument。但是,它有时仍会发生,我不知道为什么。如果是这样,应用程序崩溃了:

2012-07-06 15:24:34.470 Meernotes[11620:707] ... doc state:Normal
2012-07-06 15:24:34.472 Meernotes[11620:707] *** Terminating app due to uncaught exception 'NSInternalInconsistencyException', reason: 'closeWithCompletionHandler called while document is already closing'
*** First throw call stack:
(0x3720e88f 0x34f13259 0x3720e789 0x3720e7ab 0x312681d1 0xd19db 0x96f7f 0x9593f 0xacb8f 0x30f0cd23 0x37a7f933 0x371e2a33 0x371e2699 0x371e126f 0x371644a5 0x3716436d 0x33923439 0x30f10cd5 0x94fdd 0x94f78)
terminate called throwing an exception(lldb) 

我试图按如下方式防止崩溃,但它没有任何影响(即它仍会崩溃):

-(void)closeDoc {

    UIDocumentState state = _selectedDocument.documentState;

    NSMutableArray * states = [NSMutableArray array];
    if (state == 0) {
        [states addObject:@"Normal"];
    }
    if (state & UIDocumentStateClosed) {
        [states addObject:@"Closed"];
    }
    if (state & UIDocumentStateInConflict) {
        [states addObject:@"In conflict"];
    }
    if (state & UIDocumentStateSavingError) {
        [states addObject:@"Saving error"];
    }
    if (state & UIDocumentStateEditingDisabled) {
        [states addObject:@"Editing disabled"];
    }
    NSLog(@"... doc state: %@", [states componentsJoinedByString:@", "]);

    if (_selectedDocument.documentState & UIDocumentStateClosed) return;

    [_selectedDocument closeWithCompletionHandler:^(BOOL success) {

        NSLog(@"Closed document.");
        // Check status
        if (!success) {
            NSLog(@"Failed to close %@", _selectedDocument.fileURL);
        } else {
            _selectedDocument = nil;
        }

    }];             
}

2 个答案:

答案 0 :(得分:3)

看起来UIDocument没有存储结束状态,只有正常和已关闭,所以你必须自己做。

将此添加到您的类变量:

BOOL _documentClosing;

并在closeDoc方法中添加其用法:

-(void)closeDoc {

    if (_docClosing || (_selectedDocument.documentState & UIDocumentClosed) != 0)
        return;
    _docClosing = YES;

    [_selectedDocument closeWithCompletionHandler:^(BOOL success) {

        NSLog(@"Closed document.");
        // Check status
        if (!success) {
            NSLog(@"Failed to close %@", _selectedDocument.fileURL);
        } else {
            _selectedDocument = nil;
            _docClosing = NO;
        }

    }];             
}

答案 1 :(得分:0)

知道每个UIDocument对象只能打开和关闭一次非常重要。在实现这一点之前,我在UIDocuments中遇到了很多奇怪的问题,包括云端和本地文件。当您关闭文档时,将其指针设置为nil,因此您无法再将其关闭。如果以后需要再次访问同一文件,请使用相同的fileURL创建一个新的UID文档。

您在上面显示的错误消息是您尝试重新使用文档时显示的错误消息。