当前位置: 首页 > 工具软件 > Lang switcher > 使用案例 >

Fragment报错 java.lang.IllegalStateException: Fragment already added: XXFragment{47ad471

宣望
2023-12-01
Process: com.ws.storehouse, PID: 2937
    java.lang.IllegalStateException: Fragment already added: MainFragment{3bf077c2} (f057265a-9d7e-4720-b2ed-9aca72e54f7b) id=0x7f08012e android:switcher:2131231022:0}
        at androidx.fragment.app.FragmentStore.addFragment(FragmentStore.java:67)
        at androidx.fragment.app.FragmentManager.addFragment(FragmentManager.java:1563)
        at androidx.fragment.app.BackStackRecord.executeOps(BackStackRecord.java:405)
        at androidx.fragment.app.FragmentManager.executeOps(FragmentManager.java:2167)
        at androidx.fragment.app.FragmentManager.executeOpsTogether(FragmentManager.java:1990)
        at androidx.fragment.app.FragmentManager.removeRedundantOperationsAndExecute(FragmentManager.java:1945)
        at androidx.fragment.app.FragmentManager.execPendingActions(FragmentManager.java:1847)
        at androidx.fragment.app.FragmentManager$4.run(FragmentManager.java:413)
        at android.os.Handler.handleCallback(Handler.java:739)
        at android.os.Handler.dispatchMessage(Handler.java:95)
        at android.os.Looper.loop(Looper.java:135)
        at android.app.ActivityThread.main(ActivityThread.java:5307)
        at java.lang.reflect.Method.invoke(Native Method)
        at java.lang.reflect.Method.invoke(Method.java:372)
        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698)

 

有时候会报这样的错但是又找不到add的原因,那这种情况下一般是相关联的布局问题中出错了,也不一定是当前Fragment,可能是它的子Fragment也会提示这样的错误,所以可以优先从布局排查入手。

我的是因为 MainFragment 后边的一个Fragment 删除了布局的一个空间,但是界面上面 还有那个布局的点击事件 ,又因为那个布局ID 和MainFragment 里面控件意义一样,所以ID也一样 ,所以报错 报在前一个Fragment  MainFragment.

提示: 出错之后,想想之前改了什么东西 。

 类似资料: