gpt4 book ai didi

java - 非法状态异常 : Fragment Already Added when resuming app

转载 作者:行者123 更新时间:2023-11-30 02:45:43 25 4
gpt4 key购买 nike

概述:我有一个基于 fragment 的应用程序,只有一个 Activity 。在启动时,我添加了我的主要 fragment 并且一切正常。当我点击某物时,我调用 replace() 以换出新 fragment 并将事务添加到后台堆栈。

问题:当应用程序在后台死机(或者最容易通过“不保留 Activity ”重现),并且我从主屏幕重新启动该应用程序时,出现以下异常。

场景:1.打开应用2.导航到次要 fragment (如果你从不离开主 fragment 就不会出现这个问题)3.后台应用4. 让应用程序自然死亡(~24 小时),或在开发者选项中启用“不保留 Activity ”5. 从主屏幕打开应用

预期:应用程序打开主 fragment (无论后台显示的 fragment 是什么)

实际:下面崩溃

其他要求:- 后台应用程序和立即从主屏幕点击必须返回到前一个 fragment (假设它没有在后台被破坏)。

堆栈跟踪(注意绝对没有来 self 的应用程序本身的调用,所以我无处可调试):

java.lang.RuntimeException: Unable to start activity ComponentInfo{com.rcg.socialstitch/com.rcg.socialstitch.ViewStitchActivity}: java.lang.IllegalStateException: Fragment already added: ViewStitchFragment{42800520 #1 id=0x7f040030}
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2227)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2276)
at android.app.ActivityThread.access$800(ActivityThread.java:144)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1205)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:136)
at android.app.ActivityThread.main(ActivityThread.java:5146)
at java.lang.reflect.Method.invokeNative(Method.java)
at java.lang.reflect.Method.invoke(Method.java:515)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:795)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:611)
at dalvik.system.NativeStart.main(NativeStart.java)
Caused by: java.lang.IllegalStateException: Fragment already added: ViewStitchFragment{42800520 #1 id=0x7f040030}
at android.app.FragmentManagerImpl.addFragment(FragmentManager.java:1133)
at android.app.BackStackRecord.run(BackStackRecord.java:618)
at android.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1447)
at android.app.Activity.performStart(Activity.java:5320)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2190)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2276)
at android.app.ActivityThread.access$800(ActivityThread.java:144)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1205)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:136)
at android.app.ActivityThread.main(ActivityThread.java:5146)
at java.lang.reflect.Method.invokeNative(Method.java)
at java.lang.reflect.Method.invoke(Method.java:515)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:795)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:611)
at dalvik.system.NativeStart.main(NativeStart.java)

最佳答案

我相信我已经解决了这个问题。我的 .replace() 调用全部添加到返回堆栈,但我最初的 .add() 没有。当我确保我最初添加的 fragment 不是返回堆栈时,这似乎不再发生。

关于java - 非法状态异常 : Fragment Already Added when resuming app,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25085307/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com