java HashMap的fail-fast行为
我使用java HashMap的fail-fast行为,java,hashmap,concurrentmodification,Java,Hashmap,Concurrentmodification,我使用java.util.HashMap来了解快速失败的行为是什么 HashMap map = new HashMap(); map.put("jon", 10); map.put("sean", 11); map.put("jim", 12); map.put("stark", 13); map.put("vic", 14); Set keys = map.keySet(); for(Object k:keys) { System.out.println(map.get(k)); }
java.util.HashMap
来了解快速失败的行为是什么
HashMap map = new HashMap();
map.put("jon", 10);
map.put("sean", 11);
map.put("jim", 12);
map.put("stark", 13);
map.put("vic", 14);
Set keys = map.keySet();
for(Object k:keys) {
System.out.println(map.get(k));
}
for(Object k:keys) {
String key =(String)k;
if(key.equals("stark")) {
map.remove(key);
}
}
System.out.println("after modifn");
for(Object k:keys) {
System.out.println(map.get(k));
}
我得到了结果
12
11
10
14
13
after modifn
12
11
10
14
我还尝试使用迭代器
Iterator<String> itr = keys.iterator();
while(itr.hasNext()) {
String key = itr.next();
if(key.equals("stark")) {
map.remove(key);
}
}
Iterator itr=keys.Iterator();
while(itr.hasNext()){
String key=itr.next();
if(键等于(“斯塔克”)){
地图。删除(键);
}
}
在这两种情况下我都没有得到任何ConcurrentModificationException
。这是因为(来自javadoc)
迭代器的快速失效行为无法保证,
一般来说,不可能在未来做出任何硬保证
存在未同步的并发修改。快速失败
迭代器会尽最大努力抛出ConcurrentModificationException
我检查了另一个,其中说,它将抛出ConcurrentModificationException
。您认为如何?鉴于您显示的输出:
12
11
10
14
13 // notice this?
after modifn
12
11
10
14
由于13是最后一个键值对,因此当您通过HashMap
迭代,然后最终删除与stark 13
对应的键值时,在修改HashMap
之后,将停止迭代
,因此,它不再迭代
。因此,请不要使用ConcurrentModificationException。
尝试调用clear()
而不是remove()
。谢谢。我从未注意到..if(key.equals(“jon”)
将引发异常。。