代码之家  ›  专栏  ›  技术社区  ›  DCoder

IllegalStateException:已添加片段;无法从结构日志中找出确切的原因和位置

  •  0
  • DCoder  · 技术社区  · 6 年前

    我从Crashlytics工具google fabric得到以下日志,它显示了应用程序在生产环境中崩溃的原因。

    Fatal Exception: java.lang.IllegalStateException: Fragment already added: ProductsFragment{1e716898 #1 id=0x7f0a11fb android:switcher:2131366395:0}
       at android.support.v4.app.FragmentManagerImpl.addFragment(FragmentManager.java:1891)
       at android.support.v4.app.BackStackRecord.executeOps(BackStackRecord.java:760)
       at android.support.v4.app.FragmentManagerImpl.executeOps(FragmentManager.java:2596)
       at android.support.v4.app.FragmentManagerImpl.executeOpsTogether(FragmentManager.java:2383)
       at android.support.v4.app.FragmentManagerImpl.removeRedundantOperationsAndExecute(FragmentManager.java:2338)
       at android.support.v4.app.FragmentManagerImpl.execSingleAction(FragmentManager.java:2215)
       at android.support.v4.app.BackStackRecord.commitNowAllowingStateLoss(BackStackRecord.java:649)
       at android.support.v4.app.FragmentPagerAdapter.finishUpdate(FragmentPagerAdapter.java:145)
       at android.support.v4.view.ViewPager.populate(ViewPager.java:1238)
       at android.support.v4.view.ViewPager.populate(ViewPager.java:1086)
       at android.support.v4.view.ViewPager.onTouchEvent(ViewPager.java:2190)
       at android.view.View.dispatchTouchEvent(View.java:8472)
       at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2400)
       at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2093)
       at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2406)
       at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2050)
       at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2406)
       at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2050)
       at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2406)
       at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2050)
       at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2406)
       at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2050)
       at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2406)
       at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2050)
       at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2406)
       at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2050)
       at com.android.internal.policy.impl.PhoneWindow$DecorView.superDispatchTouchEvent(PhoneWindow.java:2369)
       at com.android.internal.policy.impl.PhoneWindow.superDispatchTouchEvent(PhoneWindow.java:1719)
       at android.app.Activity.dispatchTouchEvent(Activity.java:2786)
       at android.support.v7.view.WindowCallbackWrapper.dispatchTouchEvent(WindowCallbackWrapper.java:68)
       at android.support.v7.view.WindowCallbackWrapper.dispatchTouchEvent(WindowCallbackWrapper.java:68)
       at com.android.internal.policy.impl.PhoneWindow$DecorView.dispatchTouchEvent(PhoneWindow.java:2330)
       at android.view.View.dispatchPointerEvent(View.java:8667)
       at android.view.ViewRootImpl$ViewPostImeInputStage.processPointerEvent(ViewRootImpl.java:4558)
       at android.view.ViewRootImpl$ViewPostImeInputStage.onProcess(ViewRootImpl.java:4425)
       at android.view.ViewRootImpl$InputStage.deliver(ViewRootImpl.java:3937)
       at android.view.ViewRootImpl$InputStage.onDeliverToNext(ViewRootImpl.java:3990)
       at android.view.ViewRootImpl$InputStage.forward(ViewRootImpl.java:3956)
       at android.view.ViewRootImpl$AsyncInputStage.forward(ViewRootImpl.java:4073)
       at android.view.ViewRootImpl$InputStage.apply(ViewRootImpl.java:3964)
       at android.view.ViewRootImpl$AsyncInputStage.apply(ViewRootImpl.java:4130)
       at android.view.ViewRootImpl$InputStage.deliver(ViewRootImpl.java:3937)
       at android.view.ViewRootImpl$InputStage.onDeliverToNext(ViewRootImpl.java:3990)
       at android.view.ViewRootImpl$InputStage.forward(ViewRootImpl.java:3956)
       at android.view.ViewRootImpl$InputStage.apply(ViewRootImpl.java:3964)
       at android.view.ViewRootImpl$InputStage.deliver(ViewRootImpl.java:3937)
       at android.view.ViewRootImpl.deliverInputEvent(ViewRootImpl.java:6269)
       at android.view.ViewRootImpl.doProcessInputEvents(ViewRootImpl.java:6219)
       at android.view.ViewRootImpl.enqueueInputEvent(ViewRootImpl.java:6190)
       at android.view.ViewRootImpl$WindowInputEventReceiver.onInputEvent(ViewRootImpl.java:6359)
       at android.view.InputEventReceiver.dispatchInputEvent(InputEventReceiver.java:185)
       at android.os.MessageQueue.nativePollOnce(MessageQueue.java)
       at android.os.MessageQueue.next(MessageQueue.java:143)
       at android.os.Looper.loop(Looper.java:122)
       at android.app.ActivityThread.main(ActivityThread.java:5254)
       at java.lang.reflect.Method.invoke(Method.java)
       at java.lang.reflect.Method.invoke(Method.java:372)
       at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:902)
       at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:697)
    

    我和我的团队正在尝试重现这个崩溃,但无法做到,也无法确定应用程序崩溃的确切位置,因为日志中没有提到行号或活动名称。我们在许多屏幕上使用ProductsFragment。

    有人能帮我解决这个问题吗?

    1 回复  |  直到 6 年前
        1
  •  0
  •   AzraelPwnz    6 年前

    这是一个令人沮丧的错误进入生产。我以前也有过同样的经历。

    你是怎么添加碎片的?是否在片段管理器中使用“add”或“replace”?

    您始终可以看到堆栈中是否存在片段:

     YourFrag f = (YourFrag) fragmentManager.findFragmentByTag("MY_AWESOME_FRAG");
    
     if (f != null) {
         fm.beginTransaction()
           .replace(R.id.bottomContainer, f, "MY_AWESOME_FRAG")
           .commit();
     } else {
          fm.beginTransaction()
           .add(R.id.bottomContainer, f, "MY_AWESOME_FRAG")
           .commit();
     }