ConcurrentHashMap<String, Integer> hm = new ConcurrentHashMap<>();
hm.put("1", 1);
hm.put("2", 2);
hm.put("3", 3);
Iterator<String> itr = hm.keySet().iterator();
while(itr.hasNext()){
String key = itr.next();
System.out.println(key + " : " + hm.get(key));
hm.put("4", 4);
}
System.out.println(hm);
ConcurrentHashMap<String, Integer> hm1 = new ConcurrentHashMap<>();
hm1.put("One", 1);
hm1.put("Two", 2);
hm1.put("Three", 3);
Iterator<String> itr1 = hm1.keySet().iterator();
while(itr1.hasNext()){
String key = itr1.next();
System.out.println(key + " : " + hm1.get(key));
hm1.put("Four", 4);
}
System.out.println(hm1);
输出:1 : 12 : 23 : 34 : 4{1=1, 2=2, 3=3, 4=4}一:1二:2三:3{一=1, 四=4, 二=2, 三=3}
为什么会这样?
interator(( 调用有以下文档:https://docs.oracle.com/javase/8/docs/api/java/util/Set.html#iterator--
"元素按不按特定顺序返回">
hm.put("4", 4(
将其添加到列表的末尾(偶然?
hm1.put("Four", 4(
将其添加到 1 和 4 之间。 然而,next(( 运算符显然已经在迭代器中超过了这一点,所以对 next(( 的下一次调用已经在 Two=2。
答:
在循环访问同一列表时更改无序列表不是一个好主意。