在Map中直接删除内容将抛出 java.util.ConcurrentModificationException 异常,如果要删除可以用Iterator的remove()方法。
所以Iterator在工作的时候是不允许被迭代的对象被改变的。但可使用Iterator本身的remove()来删除对象,Iterator.remove()方法会在删除当前迭代对象的同时保持索引的一致性。
以下代码报错:
Map<String,String> map = new HashMap<String,String> ();
map.put("1", "a");
map.put("2", "b");
map.put("3", "c");
Iterator iterator = map.keySet().iterator();
while (iterator.hasNext()) {
String key = (String) iterator.next();
if ("1".equals(key) || "2".equals(key)) {
map.remove(key);
}
}
正确代码如下:
Map<String,String> map = new HashMap<String,String> ();
map.put("1", "a");
map.put("2", "b");
map.put("3", "c");
Iterator iterator = map.keySet().iterator();
while (iterator.hasNext()) {
String key = (String) iterator.next();
if ("1".equals(key) || "2".equals(key)) {
iterator.remove(); //添加该行代码
map.remove(key);
}
}
System.out.println(map.get("1"));
System.out.println(map.get("2"));
System.out.println(map.get("3"));
错误代码原因:Iterator 工作在一个独立的线程中,并拥有一个mutex锁。 Iterator被创建后会建立一个指向原来对象的单链索引表,当原来的对象数量发生变化时,这个索引表的内容不会同步改变,所以当索引指针往后移动的时候就找不到要迭代的对象,Iterator会抛出java.util.ConcurrentModificationException异常。
所以Iterator在工作的时候是不允许被迭代的对象被改变的。但可使用Iterator本身的remove()来删除对象,Iterator.remove()方法会在删除当前迭代对象的同时保持索引的一致性。