故障安全故障快速示例


    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。

答:
在循环访问同一列表时更改无序列表不是一个好主意。

相关内容

  • 没有找到相关文章

最新更新