【问题标题】:Android fragment commit illegal state exception only when phone is lockedAndroid Fragment仅在手机锁定时提交非法状态异常
【发布时间】:2014-06-23 13:47:15
【问题描述】:

我在接收广播时提交一个片段,例如

 BroadcastReceiver br = new BroadcastReceiver() {

        @Override
        public void onReceive(Context context, Intent intent) {
            // Log.e(TAG,"inside onReceive");
            if (intent.getAction().equalsIgnoreCase(
                    DATA_AVAILABLE))
                initFragments.run();
                }
     }

InitFragment 是一个带代码的可运行文件

dataBrowse = new SongListFragment();
                getSupportFragmentManager().beginTransaction()
                        ./*replace*/ add (R.id.container, dataBrowse ).commit();

它始终完美运行,除非手机被锁定。为什么会发生这种情况?这个原因的解决方案是什么?

日志:

06-23 03:56:38.210: E/AndroidRuntime(11174): FATAL EXCEPTION: main
06-23 03:56:38.210: E/AndroidRuntime(11174): java.lang.RuntimeException: Error receiving broadcast Intent { act=dat_avail flg=0x10 } in com.example.MainActivity$1@41b98e90
06-23 03:56:38.210: E/AndroidRuntime(11174):    at android.app.LoadedApk$ReceiverDispatcher$Args.run(LoadedApk.java:765)
06-23 03:56:38.210: E/AndroidRuntime(11174):    at android.os.Handler.handleCallback(Handler.java:615)
06-23 03:56:38.210: E/AndroidRuntime(11174):    at android.os.Handler.dispatchMessage(Handler.java:92)
06-23 03:56:38.210: E/AndroidRuntime(11174):    at android.os.Looper.loop(Looper.java:137)
06-23 03:56:38.210: E/AndroidRuntime(11174):    at android.app.ActivityThread.main(ActivityThread.java:4898)
06-23 03:56:38.210: E/AndroidRuntime(11174):    at java.lang.reflect.Method.invokeNative(Native Method)
06-23 03:56:38.210: E/AndroidRuntime(11174):    at java.lang.reflect.Method.invoke(Method.java:511)
06-23 03:56:38.210: E/AndroidRuntime(11174):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1006)
06-23 03:56:38.210: E/AndroidRuntime(11174):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:773)
06-23 03:56:38.210: E/AndroidRuntime(11174):    at dalvik.system.NativeStart.main(Native Method)
06-23 03:56:38.210: E/AndroidRuntime(11174): Caused by: java.lang.IllegalStateException: Can not perform this action after onSaveInstanceState
06-23 03:56:38.210: E/AndroidRuntime(11174):    at android.support.v4.app.FragmentManagerImpl.checkStateLoss(FragmentManager.java:1343)
06-23 03:56:38.210: E/AndroidRuntime(11174):    at android.support.v4.app.FragmentManagerImpl.enqueueAction(FragmentManager.java:1361)
06-23 03:56:38.210: E/AndroidRuntime(11174):    at android.support.v4.app.BackStackRecord.commitInternal(BackStackRecord.java:595)
06-23 03:56:38.210: E/AndroidRuntime(11174):    at android.support.v4.app.BackStackRecord.commit(BackStackRecord.java:574)
06-23 03:56:38.210: E/AndroidRuntime(11174):    at com.example.MainActivity$3.run(MainActivity.java:228)
06-23 03:56:38.210: E/AndroidRuntime(11174):    at com.example.MainActivity$1.onReceive(MainActivity.java:101)
06-23 03:56:38.210: E/AndroidRuntime(11174):    at android.app.LoadedApk$ReceiverDispatcher$Args.run(LoadedApk.java:755)
06-23 03:56:38.210: E/AndroidRuntime(11174):    ... 9 more
06-23 03:56:38.245: I/Process(11174): Sending signal. PID: 11174 SIG: 9

【问题讨论】:

    标签: android android-fragments illegalstateexception android-actionbaractivity


    【解决方案1】:

    我认为您的程序中发生了状态丢失,一种解决方案是保存实例并恢复避免状态丢失的实例,另一个是提交允许状态丢失,您可以查看 blogspot @987654321 @

    【讨论】:

    • 如果我没有设置setRetainStatecommit allowing stateloss会有什么影响?
    • 仅将 commitAllowingStateLoss() 用作最后的手段。调用 commit() 和 commitAllowingStateLoss() 的唯一区别是,如果发生状态丢失,后者不会抛出异常。通常你不想使用这种方法,因为它暗示有可能发生状态丢失。当然,更好的解决方案是编写您的应用程序,以保证在保存活动状态之前调用 commit(),因为这将带来更好的用户体验。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2013-01-13
    • 2023-03-23
    • 1970-01-01
    相关资源
    最近更新 更多