Java基础-Iterator与ListIterator(迭代器)

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

猜你喜欢

转载自blog.csdn.net/weixin_40649194/article/details/89112780