1

UIDoc を 2 回閉じようとしたときにクラッシュを防ぐ方法を知りたいです。私は自分のコードで、(理論的には) UIDocument を 2 回閉じることができないことを確認しようとしました。しかし、それでも時々発生し、その理由はわかりません。その場合、アプリはクラッシュします。

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

    }];             
}
4

2 に答える 2

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

    }];             
}
于 2012-07-06T14:42:04.853 に答える
0

各UIDocumentオブジェクトは一度しか開いたり閉じたりできないことを知っておくことが非常に重要です。クラウドとローカルファイルの両方で、これに気付く前にUIDocumentsで多くの奇妙な問題が発生しました。ドキュメントを閉じるときは、そのポインタをnilに設定して、再度閉じることができないようにします。後で同じファイルに再度アクセスする必要がある場合は、同じfileURLを使用して新しいUIDocumentを作成します。

上記のエラーメッセージは、ドキュメントを再利用しようとしたときに表示されるメッセージです。

于 2012-07-14T23:06:08.163 に答える