2012-01-05 13 views
12

私のアクティビティで起こっている他のものと一緒に断片を処理することはまだ明らかではありません。次は、スタックトレースです: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は違いを生み出すでしょうか?

私のテストでは状況を再現することができませんでしたので、レポートにしか表示されません。

答えて

15

トレースを見ると明らかな問題は、onResumeより前に呼び出されたonActivityResultメソッドのコードからpopStackを呼び出していることです。私はonResumeへの呼び出しを移して固定しました。

+0

私は同じ問題があり、私のコードは 'onResume()'にあります – noloman

+0

これは正しい解決策ではありません。 –

+0

@metalurgusこれは3歳です。 Androidの新しいバージョンで同じまたは類似の問題が発生している場合は、新しい質問を投稿する必要があります。この質問にリンクし、質問が重複することを避けるためにあなたの状況がどのように異なるかを説明してください。 –

関連する問題