前言
项目中会用Viewpager+Fragment来显示图片,先项目中测试ok,但是我单独拎出来做简单调试时出现:
java.lang.IllegalStateException: Fragment already added: PlayFragment
尴尬了,就我拎出来的demo代码片段有问题。
最后调试发现,是我测试数据的问题。
简单记录于此,以便提醒自己。
好记性不如烂笔头
正文
异常的部分日志:
AndroidRuntime( 6843): Shutting down VM
AndroidRuntime( 6843): FATAL EXCEPTION: main
AndroidRuntime( 6843): Process: com.biumall.image, PID: 6843
AndroidRuntime( 6843): java.lang.IllegalStateException: Fragment already added: PlayFragment{d00a1dd} (5d7297c6-1e8d-4006-b51a-6d371a996c1f id=0x7f080072)
AndroidRuntime( 6843): at androidx.fragment.app.FragmentStore.addFragment(FragmentStore.java:91)
AndroidRuntime( 6843): at androidx.fragment.app.FragmentManager.addFragment(FragmentManager.java:1713)
AndroidRuntime( 6843): at androidx.fragment.app.BackStackRecord.executeOps(BackStackRecord.java:415)
AndroidRuntime( 6843): at androidx.fragment.app.FragmentManager.executeOps(FragmentManager.java:2404)
AndroidRuntime( 6843): at androidx.fragment.app.FragmentManager.executeOpsTogether(FragmentManager.java:2162)
AndroidRuntime( 6843): at androidx.fragment.app.FragmentManager.removeRedundantOperationsAndExecute(FragmentManager.java:2100)
AndroidRuntime( 6843): at androidx.fragment.app.FragmentManager.execSingleAction(FragmentManager.java:1971)
AndroidRuntime( 6843): at androidx.fragment.app.BackStackRecord.commitNowAllowingStateLoss(BackStackRecord.java:311)
AndroidRuntime( 6843): at androidx.fragment.app.FragmentStatePagerAdapter.finishUpdate(FragmentStatePagerAdapter.java:274)
AndroidRuntime( 6843): at androidx.viewpager.widget.ViewPager.populate(ViewPager.java:1244)
AndroidRuntime( 6843): at androidx.viewpager.widget.ViewPager.populate(ViewPager.java:1092)
AndroidRuntime( 6843): at androidx.viewpager.widget.ViewPager.onMeasure(ViewPager.java:1622)
原因分析
网上也有人记录原因,比如:
一般是因为fragment中有错误
我也测试过,直接吧我Fragment删除,使用简单的fragment替换,但依旧错误,因此我的不是上面的原因。
最后我打印ViewPagerAdapter所有日志:
Image_ViewPagerAdapter( 6843): getItem position : 0
Image_ViewPagerAdapter( 6843): getItem mPlayFragment : PlayFragment{d00a1dd} (5d7297c6-1e8d-4006-b51a-6d371a996c1f)
Image_ViewPagerAdapter( 6843): getItem position : 1
Image_ViewPagerAdapter( 6843): getItem mPlayFragment : PlayFragment{d00a1dd} (5d7297c6-1e8d-4006-b51a-6d371a996c1f id=0x7f080072)
发现,数据中0和1的PlayFragment对象竟然一样的!!!
查看插入图片的数据:
mImageList.add("/storage/udisk1/125la.png");
mImageList.add("/storage/udisk1/125la.png");
mImageList.add("/storage/udisk1/125la.png");
mImageList.add("/storage/udisk1/125la.png");
哎,为了偷懒,使用了重复数据,没想倒创建的PlayFragment以url为唯一的标志。
解决方式
把数据改成不同样的即可:
mImageList.add("/storage/udisk1/125la_1.jpg");
mImageList.add("/storage/udisk1/125la_2.jpg");
mImageList.add("/storage/udisk1/125la_3.jpg");
mImageList.add("/storage/udisk1/125la_4.jpg");
mImageList.add("/storage/udisk1/125la_5.jpg");
mImageList.add("/storage/udisk1/125la_6.jpg");
每个人出现的情况可能不一样,以上仅供参考。谢谢
参考文章
© 版权声明