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.
提示: 出错之后,想想之前改了什么东西 。