先把异常截图抛出来供大家参考
具体的异常信息就是java.util.ConcurrentModificationException: null
出来之后满头雾水,然后根据提示找到对应的出错代码位置(改为测试方法)
复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19 @Test public void test(){ List<TestBO> list=new ArrayList(); TestBO testBO=new TestBO(); testBO.setCopyBOne("one"); list.add(testBO); TestDO testDO=new TestDO(); testDO.setCopyDOne("one"); if (!CollectionUtils.isEmpty(list)) { for (TestBO identifyDO : list) { if (testDO.getCopyDOne().equals(identifyDO.getCopyBOne())) { list.remove(identifyDO); } } } }
可以发现是调用list的remove()方法导致出现异常
查看ArrayList类的remove()方法的源码,找到对应的异常点了
这个抛异常是因为删除某个元素之后,后面每位元素后移了一位,索引加一,所以导致实际访问的元素与删除的元素中间差了一位
我的解决方法:
复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17@Test public void test(){ List<TestBO> list=new ArrayList(); TestBO testBO=new TestBO(); testBO.setCopyBOne("one"); list.add(testBO); TestDO testDO=new TestDO(); testDO.setCopyDOne("one"); if (!CollectionUtils.isEmpty(list)) { for (TestBO testBO1 : list) { if (testDO.getCopyDOne().equals(testBO1.getCopyBOne())) { list.remove(testBO1); break;//直接break掉,后面就不会进入满足业务 } } } }
其他的解决方法:
还有反向遍历解决问题的,我的业务逻辑比较简单就直接选择了break。
记一位初出茅庐的女程序初次博客书写记录(感动,我都开始写博客了。泪目)
最后
以上就是平常小虾米最近收集整理的关于记一次异常问题解决 java.util.ConcurrentModificationException: null的全部内容,更多相关记一次异常问题解决内容请搜索靠谱客的其他文章。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复