在集合的使用过程中,有时候我们选择迭代器操作。
一般处理方式如下
接上面的代码后,再向linkedList中加入一个"vv",然后再使用原来的迭代器获取。
因为当前的迭代器状态是基于之前状态的linkedList,所以此时的迭代器不能够操作状态发生改变的集合。当linkedList中的数据发生改变时,只有重新再获取一次迭代器,才可以操作状态更改后的linkedList。只要是Iterator体中的所有类都有这个问题。每一次目标对象状态改变后,都要重新来获取新的迭代器对象。伙伴们小心。
一般处理方式如下
LinkedList<Object> linkedList = new LinkedList<>();
linkedList.add("2");
linkedList.add("3");
linkedList.add("4");
linkedList.add("5");
System.err.println(linkedList.toString());
Iterator<Object> iterator = linkedList.iterator();
boolean hasNext = iterator.hasNext();
if(hasNext){
iterator.next();
}
但是如果在你在获取迭代器对象后,又使用linkedList对象操作了数据,那么下一次再使用迭代器时就会出错了。
增加如下代码,如进行如下操作: linkedList.add("vv");
hasNext = iterator.hasNext();
if(hasNext){
iterator.next();
}
接上面的代码后,再向linkedList中加入一个"vv",然后再使用原来的迭代器获取。
报错如下:
Exception in thread "main" java.util.ConcurrentModificationException
at java.util.LinkedList$ListItr.checkForComodification(LinkedList.java:953)
at java.util.LinkedList$ListItr.next(LinkedList.java:886)
at org.test.Test.main(Test.java:29)
因为当前的迭代器状态是基于之前状态的linkedList,所以此时的迭代器不能够操作状态发生改变的集合。当linkedList中的数据发生改变时,只有重新再获取一次迭代器,才可以操作状态更改后的linkedList。只要是Iterator体中的所有类都有这个问题。每一次目标对象状态改变后,都要重新来获取新的迭代器对象。伙伴们小心。