我是靠谱客的博主 孝顺苗条,这篇文章主要介绍关于for循环和迭代器嵌套使用产生的bug关于for循环和迭代器嵌套使用产生的bug,现在分享给大家,希望可以做个参考。

关于for循环和迭代器嵌套使用产生的bug

话不多说,先上代码

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
//新建修改汇总的集合 List<Receivable> updateReceivableSumAuditList = new ArrayList<>(); //遍历查询出的汇总的数据 Iterator<Receivable> receivableIterator = receivableList.iterator(); sumAuditList.forEach(receivableSumAudit -> { while (receivableIterator.hasNext()) { Receivable receivable = receivableIterator.next(); if (receivable.getOrgId().equals(receivableSumAudit.getOrgId()) && receivable.getRecDate().equals(receivableSumAudit.getTransDate())) { updateReceivableSumAuditList.add(receivable); receivableIterator.remove(); } } });

我在for循环中使用了迭代器,迭代器中的list集合在测试中是有三条数据的,发现对迭代器进行遍历时,遍历到最后一条数据时,迭代器的hasNext就直接就变为false,导致最后一条数据没有遍历到,具体原因未知,百度也没找到原理,最后我没有使用迭代器,使用下面的新代码后,程序可以正常运行了:

复制代码
1
2
3
4
5
6
7
8
9
10
//新建修改汇总的集合 List<Receivable> updateReceivableSumAuditList = new ArrayList<>(); //遍历查询出的汇总的数据 sumAuditList.forEach(receivableSumAudit -> { List<Receivable> collect = receivableList.stream().filter(receivable -> receivable.getOrgId().equals(receivableSumAudit.getOrgId()) && receivable.getRecDate().equals(receivableSumAudit.getTransDate())).collect(Collectors.toList()); updateReceivableSumAuditList.addAll(collect); }); receivableList.removeAll(updateReceivableSumAuditList);

我原理是不知道了,算是踩了个坑,告诫不知道的人:迭代器不要和for循环一起使用。
欢迎大佬来解释下原理(_

最后

以上就是孝顺苗条最近收集整理的关于关于for循环和迭代器嵌套使用产生的bug关于for循环和迭代器嵌套使用产生的bug的全部内容,更多相关关于for循环和迭代器嵌套使用产生内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(50)

评论列表共有 0 条评论

立即
投稿
返回
顶部