我有一个 Live Android 应用程序,并且从市场上我收到了以下堆栈跟踪,我不知道为什么它会发生,因为它没有发生在应用程序代码中,而是由应用程序中的某些或其他事件引起的(假设)
我没有使用 Fragments,仍然有 FragmentManager 的引用。 如果任何机构可以揭示一些隐藏的事实以避免此类问题:
java.lang.IllegalStateException: Can not perform this action after onSaveInstanceState
at android.app.FragmentManagerImpl.checkStateLoss(FragmentManager.java:1109)
at android.app.FragmentManagerImpl.popBackStackImmediate(FragmentManager.java:399)
at android.app.Activity.onBackPressed(Activity.java:2066)
at android.app.Activity.onKeyDown(Activity.java:1962)
at android.view.KeyEvent.dispatch(KeyEvent.java:2482)
at android.app.Activity.dispatchKeyEvent(Activity.java:2274)
at com.android.internal.policy.impl.PhoneWindow$DecorView.dispatchKeyEvent(PhoneWindow.java:1668)
at android.view.ViewGroup.dispatchKeyEvent(ViewGroup.java:1112)
at android.view.ViewGroup.dispatchKeyEvent(ViewGroup.java:1112)
at android.view.ViewGroup.dispatchKeyEvent(ViewGroup.java:1112)
at android.view.ViewGroup.dispatchKeyEvent(ViewGroup.java:1112)
at android.view.ViewGroup.dispatchKeyEvent(ViewGroup.java:1112)
at android.view.ViewGroup.dispatchKeyEvent(ViewGroup.java:1112)
at com.android.internal.policy.impl.PhoneWindow$DecorView.superDispatchKeyEvent(PhoneWindow.java:1720)
at com.android.internal.policy.impl.PhoneWindow.superDispatchKeyEvent(PhoneWindow.java:1258)
at android.app.Activity.dispatchKeyEvent(Activity.java:2269)
at com.android.internal.policy.impl.PhoneWindow$DecorView.dispatchKeyEvent(PhoneWindow.java:1668)
at android.view.ViewRoot.deliverKeyEventPostIme(ViewRoot.java:2851)
at android.view.ViewRoot.handleFinishedEvent(ViewRoot.java:2824)
at android.view.ViewRoot.handleMessage(ViewRoot.java:2011)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:132)
at android.app.ActivityThread.main(ActivityThread.java:4025)
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:841)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:599)
at dalvik.system.NativeStart.main(Native Method)
最佳答案
这是迄今为止我遇到的最愚蠢的错误。我有一个 Fragment
应用程序非常适合 API < 11 和 Force Closing
关于 API > 11。
我真的不知道他们在 saveInstance
调用中的 Activity
生命周期内发生了什么变化,但我是这样解决这个问题的:
@Override
protected void onSaveInstanceState(Bundle outState) {
//No call for super(). Bug on API Level > 11.
}
我只是不调用 .super()
并且一切正常。我希望这可以为您节省一些时间。
编辑: 经过更多研究,这是一个已知的 bug在支持包中。
如果您需要保存实例,并向您的 outState
Bundle
添加一些内容,您可以使用以下内容:
@Override
protected void onSaveInstanceState(Bundle outState) {
outState.putString("WORKAROUND_FOR_BUG_19917_KEY", "WORKAROUND_FOR_BUG_19917_VALUE");
super.onSaveInstanceState(outState);
}
EDIT2: 如果您在 Activity
退出后台后尝试执行事务,也可能会发生这种情况。为避免这种情况,您应该使用 commitAllowingStateLoss()
EDIT3: 据我所知,上述解决方案正在修复早期 support.v4 库中的问题。但如果您对此仍有疑问,您必须还阅读 @AlexLockwood的博客:Fragment Transactions & Activity State Loss
博文摘要(但我强烈建议您阅读):
- NEVER
commit()
事务在onPause()
在 pre-Honeycomb 和onStop()
之后后蜂窝 - 在
Activity
生命周期方法中提交事务时要小心。 使用onCreate()
、onResumeFragments()
和onPostResume()
- 避免在异步回调方法中执行事务
- 仅将
commitAllowingStateLoss()
用作最后的手段
关于android - 获取异常 "IllegalStateException: Can not perform this action after onSaveInstanceState",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7469082/