Java基础-Iterator与ListIterator(迭代器)
Demo
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.ListIterator;
public class Demo1 {
public static void main(String[] args) {
// 创建List集合对象
List list = new ArrayList();
// 创建元素对象
String s1 = "CSDN";
String s2 = "zhongyp";
// 将元素添加到集合中
list.add(s1);
list.add(s2);
//提示java.util.ConcurrentModificationException错误
/* IteratorClass.run(list); */
//执行成功
ListIteratorClass.run(list);
}
}
class ListIteratorClass {
public static void run(List list) {
// 利用迭代器遍历,修改迭代器,由于Iterator中没有add方法,所以用其子接口ListIterator
ListIterator li = list.listIterator();
while (li.hasNext()) {
String s = (String) li.next();
if ("zhongyp".equals(s)) {
li.add("Ariel");
}
}
System.out.println(list);
}
}
class IteratorClass {
public static void run(List list) {
// 利用迭代器遍历
Iterator li = list.iterator();
while (li.hasNext()) {
String s = (String) li.next();
if ("zhongyp".equals(s)) {
list.add("Ariel");
}
}
System.out.println(list);
}
}
错误原因(重点)
IteratorClass.run(list);提示java.util.ConcurrentModificationException错误
是由于list的modeCount与it的expectedModCount不相等,每次执行li.next();的时候都会对比modeCount与expectedModCount,不相等,于是抛出异常。
modCount表示列表(list)被结构性修改(structurally modified)的次数,即add,addAll,remove, fastRemove,clear, removeRange, ensureCapacity, ensureCapacityInternal, ensureExplicitCapacity等方法都会使modCount加1。
当使用iterator方法得到Iterator对象时把modCount的值赋给了expectedModCount。
当继续对集合进行上诉会使得modCount加1的操作时,modCount就不等于expectedModCount,于是抛出异常。
解决方案
解决方案一:
由于Iterator中没有add方法,所以用其子接口ListIterator即可。
解决方案二:
使用for循环(增强for循环)
本人写的比较粗浅,可移驾到:
https://blog.csdn.net/kingzone_2008/article/details/41368989
大佬写的不错0.0