Подтвердить что ты не робот

Android: не удается выполнить это действие после onSaveInstanceState

Я все еще явно не понимаю, как обрабатывать фрагменты вместе с другими вещами, происходящими в моей деятельности. Ниже показана трассировка стека:

java.lang.RuntimeException: Failure delivering result ResultInfo{who=null, request=2, result=-1, data=Intent { (has extras) }} to activity {com.ghcssoftware.gedstar/com.ghcssoftware.gedstar.GedStar}: java.lang.IllegalStateException: Can not perform this action after onSaveInstanceState
at android.app.ActivityThread.deliverResults(ActivityThread.java:2747)
at android.app.ActivityThread.handleSendResult(ActivityThread.java:2790)
at android.app.ActivityThread.access$2000(ActivityThread.java:122)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1035)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:132)
at android.app.ActivityThread.main(ActivityThread.java:4028)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:491)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:844)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:602)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.IllegalStateException: Can not perform this action after onSaveInstanceState
at android.support.v4.app.FragmentManagerImpl.checkStateLoss(FragmentManager.java:1299)
at android.support.v4.app.FragmentManagerImpl.enqueueAction(FragmentManager.java:1310)
**at android.support.v4.app.FragmentManagerImpl.popBackStack(FragmentManager.java:471)
at com.ghcssoftware.gedstar.PersonTab$PersonTabFrag.popStack(PersonTab.java:157)**
at com.ghcssoftware.gedstar.PersonTab$PersonTabFrag.fillData(PersonTab.java:165)
at com.ghcssoftware.gedstar.ViewTab.fillData(ViewTab.java:96)
at com.ghcssoftware.gedstar.GedStar.fillData(GedStar.java:589)
at com.ghcssoftware.gedstar.GedStar.onActivityResult(GedStar.java:514)
at android.app.Activity.dispatchActivityResult(Activity.java:4541)
at android.app.ActivityThread.deliverResults(ActivityThread.java:2743)

Итак, похоже, что это мой вызов popBackStack внутри этой функции, где я очищаю любые сложенные фрагменты в одной из панелей просмотра:

    // Pop fragments from second pane
    private void popStack() {
        if (mDualPane && mBottomId >= 0) {
            mViewTab.getTabHelper().tabGetFragManager().popBackStack(mBottomId, 
                    FragmentManager.POP_BACK_STACK_INCLUSIVE);
            mBottomId = -1;
        }
    }

В основном я не уверен, почему происходит это из-за того, что "после того, как onSaveInstanceState" был вызван, или если это действительно происходит. Любые возможные объяснения? Будет ли popBackStackImmediate иметь значение?

Для чего это стоит, я не смог воссоздать обстоятельства в своем тестировании, поэтому он отображается только в отчетах.

4b9b3361

Ответ 1

Проблема, которая очевидна при просмотре трассировки, заключается в том, что я вызывал popStack из кода в свой метод onActivityResult, который вызывается до onResume. Я перевел вызов onResume и исправил его.