Map中删除数据 或是key

在Map中直接删除内容将抛出 java.util.ConcurrentModificationException 异常,如果要删除可以用Iterator的remove()方法。
以下代码报错:
Java代码 复制代码  收藏代码
  1. Map map = new HashMap ();   
  2. map.put("1""a");   
  3. map.put("2""b");   
  4. map.put("3""c");   
  5. Iterator iterator = map.keySet().iterator();    
  6. while (iterator.hasNext()) {   
  7.     String key = (String) iterator.next();   
  8.     if ("1".equals(key) || "2".equals(key)) {   
  9.        map.remove(key);   
  10.     }   
  11.  }  
Map map = new HashMap ();
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);
    }
 }

正确代码如下:
Java代码 复制代码  收藏代码
  1. Map map = new HashMap ();   
  2. map.put("1""a");   
  3. map.put("2""b");   
  4. map.put("3""c");   
  5. Iterator iterator = map.keySet().iterator();    
  6. while (iterator.hasNext()) {   
  7.     String key = (String) iterator.next();   
  8.     if ("1".equals(key) || "2".equals(key)) {   
  9.        iterator.remove();        //添加该行代码   
  10.         map.remove(key);       
  11.      }   
  12.  }   
  13. System.out.println(map.get("1"));   
  14. System.out.println(map.get("2"));   
  15. System.out.println(map.get("3"));  
Map map = new HashMap ();
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()方法会在删除当前迭代对象的同时保持索引的一致性。

你可能感兴趣的:(java)