gpt4 book ai didi

java.lang.IllegalStateException : Fragment already added 错误

转载 作者:搜寻专家 更新时间:2023-10-30 21:20:34 24 4
gpt4 key购买 nike

我在使用目标 SDK 4.3 编译和运行 Android 应用程序时遇到问题。该应用程序有两个 Activity ,一个是启动器 Activity 的 MainActivity 和一个 SecondActivity。两者都在使用 fragment 。为了也支持旧设备,使用了支持库。

在以下场景中会出现“IllegalStateException: Fragment already added”错误。

1) 启动应用程序 -> 显示 MainActivity
2) 切换到带有 Intent 的 SecondActivity
3) 按主页按钮
4) 等待时间较长(以24小时测试)
5) 再次按下应用程序图标 -> 异常。如果时间较短,则 SecondActivity 会按预期显示。

我已经阅读了很多 fragment 处理期间的 IllegalStateExceptions,但所有这些都指出了 replace() 方法的问题。在 Stacktrace 中,我自己的代码从未被调用。

在Activies的onCreate()方法中添加了Fragement:

protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(..);
ListFragment listFragment = this.getCaptureListFragment();
FragmentTransaction tx = this.getSupportFragmentManager().beginTransaction();
tx.add(R.id.MainFragmentContainer, listFragment, "list_fragment_tag");
tx.commit();
}

private ListFragment getListFragment() {
ListFragment listFragment = (ListFragment) this.getSupportFragmentManager().findFragmentByTag("list_fragment_tag");
if (listFragment == null) {
listFragment = new ListFragment();
}
return listFragment;
}


java.lang.RuntimeException: Unable to start activity ComponentInfo{de.myexample.demo/de.myexample.demo.ui.SecondActivity}: java.lang.IllegalStateException: Fragment already added: ListFragment{42283f58 #0 id=0x7f060094 de.myexample.demo.ui.ListFragment}
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2211)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2261)
at android.app.ActivityThread.access$600(ActivityThread.java:141)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1256)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:5103)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:525)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:737)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.IllegalStateException: Fragment already added: ListFragment{42283f58 #0 id=0x7f060094 de.myexample.demo.ui.ListFragment}
at android.support.v4.app.FragmentManagerImpl.addFragment(SourceFile:1175)
at android.support.v4.app.BackStackRecord.run(SourceFile:616)
at android.support.v4.app.FragmentManagerImpl.execPendingActions(SourceFile:1460)
at android.support.v4.app.FragmentActivity.onStart(SourceFile:556)
at android.app.Instrumentation.callActivityOnStart(Instrumentation.java:1171)
at android.app.Activity.performStart(Activity.java:5143)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2184)
... 11 more
java.lang.IllegalStateException: Fragment already added: ListFragment{42283f58 #0 id=0x7f060094 de.myexample.demo.ui.ListFragment}
at android.support.v4.app.FragmentManagerImpl.addFragment(SourceFile:1175)
at android.support.v4.app.BackStackRecord.run(SourceFile:616)
at android.support.v4.app.FragmentManagerImpl.execPendingActions(SourceFile:1460)
at android.support.v4.app.FragmentActivity.onStart(SourceFile:556)
at android.app.Instrumentation.callActivityOnStart(Instrumentation.java:1171)
at android.app.Activity.performStart(Activity.java:5143)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2184)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2261)
at android.app.ActivityThread.access$600(ActivityThread.java:141)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1256)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:5103)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:525)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:737)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
at dalvik.system.NativeStart.main(Native Method)

最佳答案

好的,我自己解决了。

我将所有 fragment 放在 onPause() 中,并将状态存储在一些 boolean 值中。根据该 boolean 值, fragment 被放入 onResume() 中。无论 Activity 在后台运行多长时间,启动都是稳定的。

boolean addList = false;

@Override
protected void onResume() {
FragmentTransaction tx = this.getSupportFragmentManager().beginTransaction();
if (this.addList) {
ListFragment list = this.getListFragment();
tx.add(R.id.MainFragmentContainer, list, "list_fragment_tag");
}

tx.commit();
super.onResume();

this.addList = false;

}

@Override
protected void onPause() {
this.addList = this.getListFragment().isAdded();
...
if (this.addList) {
FragmentTransaction tx = this.getSupportFragmentManager().beginTransaction();
tx.remove(this.getListFragment());
tx.commit();
}
this.getSupportFragmentManager().executePendingTransactions();
super.onPause();

}

也许这对遇到同样问题的人有帮助

关于java.lang.IllegalStateException : Fragment already added 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19441932/

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