迭代器与快速失败
List<Employee> list = new ArrayList<>();
Employee employee = new Employee("w", 2);
list.add(employee);
list.add(new Employee("q",8));
Iterator<Employee> iterator = list.iterator();
while (iterator.hasNext()) {
Employee next = iterator.next();
if (next.getAge()==2){
iterator.remove();
}
next.setAge(6);
System.out.println("ttt");
}
System.out.println(list);
为什么不会空指针?
因为remove()方法并没有删除迭代器的对象,删除的是arrayList中的。所以就不会出现空指针问题。
快速失败回顾,在这个方法中也可以看出,使用迭代器不会发生快速失败,因为,进行了modCount进行了赋值,所以在checkForComodification()时会是准确的,因为for循环也是使用的iterator迭代器,但是你在删除时,直接使用的是ArrayList.this.remove()方法,就可能出现快速失败的问题。在next()也会校验modCount。
public void remove() {
if (lastRet < 0)
throw new IllegalStateException();
checkForComodification();
try {
ArrayList.this.remove(lastRet);
cursor = lastRet;
lastRet = -1;
expectedModCount = modCount;
} catch (IndexOutOfBoundsException ex) {
throw new ConcurrentModificationException();
}
}