[size=large]JAVA程序员不可不用的集合操作,但是很多时间大家是否注意过其中的问题,最近又回到了基础中,学习JAVASE中基本知识。当有过一段工作时间后,再回头看看基础的知识,往往会有更深入的了解。[/size]
[size=large]
总结小知识点如下
[/size]
[size=large]
在集合的使用过程中,有时候我们选择迭代器操作。
一般处理方式如下
[/size]
[size=large]
但是如果在你在获取迭代器对象后,又使用linkedList对象操作了数据,那么下一次再使用迭代器时就会出错了。
增加如下代码,如进行如下操作:
[/size]
[size=large]
接上面的代码后,再向linkedList中加入一个"vv",然后再使用原来的迭代器获取。
报错如下:
[/size]
[size=large]因为当前的迭代器状态是基于之前状态的linkedList,所以此时的迭代器不能够操作状态发生改变的集合。当linkedList中的数据发生改变时,只有重新再获取一次迭代器,才可以操作状态更改后的linkedList。只要是Iterator体中的所有类都有这个问题。每一次目标对象状态改变后,都要重新来获取新的迭代器对象。伙伴们小心[/size]
[size=large]
总结小知识点如下
[/size]
[size=large]
在集合的使用过程中,有时候我们选择迭代器操作。
一般处理方式如下
[/size]
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();
}
[size=large]
但是如果在你在获取迭代器对象后,又使用linkedList对象操作了数据,那么下一次再使用迭代器时就会出错了。
增加如下代码,如进行如下操作:
[/size]
linkedList.add("vv");
hasNext = iterator.hasNext();
if(hasNext){
iterator.next();
}
[size=large]
接上面的代码后,再向linkedList中加入一个"vv",然后再使用原来的迭代器获取。
报错如下:
[/size]
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)
[size=large]因为当前的迭代器状态是基于之前状态的linkedList,所以此时的迭代器不能够操作状态发生改变的集合。当linkedList中的数据发生改变时,只有重新再获取一次迭代器,才可以操作状态更改后的linkedList。只要是Iterator体中的所有类都有这个问题。每一次目标对象状态改变后,都要重新来获取新的迭代器对象。伙伴们小心[/size]