コアデータの上に小さなアプリを開発しています。起動時に、メンテナンス タスクを開始する必要があります。高速ですが重要です。このタスクを実行するには、アプリ デリゲートが UIManagedDocument を開き、さまざまなチェックを実行する必要があります。チェックが完了するまで、アプリ ビューを開始しないでください。UIMD を開くことは非同期であるため、最初の UIview がドキュメントにアクセスしようとしたときに、アプリの委任は完了しません。ドキュメントの状態がまだ確定していない間に、アプリ デリゲートとビューがドキュメントを同時に開こうとするため、競合状態が原因でアプリケーションがクラッシュします。
絵コンテを使っているので、セグエはほぼOS任せ… 次回は全部手動でやってみようかな..
あなたの推奨事項は何ですか?注: 1) アプリのときはタスクを実行できません。バックグラウンド状態に戻ります。これは、元のデータベースとビューに表示される内容との間で矛盾した状態を回避するのが非常に面倒になるためです。2) 同じ理由で、通常の実行中に保守タスクを実行することは容易ではありません。3) すべてのビューは、ここで提案されているコードに従って、シングルトンを介して UIMD にアクセスします。
UIView でミューテックス ロックを設定することは、私の好みのルートではありません。アプリのデリゲートによって解放されるまで、タブ バーを表示している間、画面が黒のまま (データがない) であるためです。
コントロールを UIViews に渡す前に、アプリのデリゲートにシグナルを待機させる方法はありますか? この場合、落とし穴はありますか? これはおそらく推奨される方法ではないと思います。デリゲートがメンテナンス タスクの完了を待つ時間が長すぎると、iOS がアプリを強制終了する可能性があります。この場合、「長すぎる」とは何でしょうか。