2012-01-05 47 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」被調用後,或者如果這是真正發生的事情。任何可能的解釋? popBackStack會立即起作用嗎?

對於它的價值,我無法在測試中重新創建環境,因此只能在報告中顯示。

回答

15

從查看跟蹤中可以明顯地看出問題,那就是我在我的onActivityResult方法中調用了popStack,該方法在onResume之前調用。我把這個電話轉到了onResume並修復了它。

+0

我有同樣的問題,我的代碼是在'onResume()' – noloman 2013-01-23 08:43:12

+0

這是不正確的解決方案。 – 2015-01-30 13:52:59

+0

@metalurgus這是3歲。如果您在Android的較新版本中遇到相同或相似的問題,則可能需要發佈一個新問題。鏈接到這個問題,並解釋你的情況是如何不同,以避免你的問題作爲重複關閉。 – 2015-01-30 13:54:45

相關問題