1. 程式人生 > >刪除map中的鍵值對內容

刪除map中的鍵值對內容

    Iterator<String> iterator = map.keySet().iterator();// map中key(鍵)的迭代器物件
        while (iterator.hasNext()){// 迴圈取鍵值進行判斷
            String key = iterator.next();// 鍵
            if(key.startsWith("a")){
                iterator.remove();// 移除map中以a字元開頭的鍵對應的鍵值對
            }
        }


在Map中直接刪除內容將丟擲 java.util.ConcurrentModificationException 異常,如果要刪除可以用Iterator的remove()方法。
以下程式碼報錯: 
  1. Map<String,String> map = new HashMap<String,String> ();
  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. }

正確程式碼如下:
  1. Map<String,String> map = new HashMap<String,String> ();
  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"));

錯誤程式碼原因:Iterator工作在一個獨立的執行緒中,並擁有一個mutex鎖。Iterator被建立後會建立一個指向原來物件的單鏈索引表
當原來的物件數量發生變化時,這個索引表的內容不會同步改變,所以當索引指標往後移動的時候就找不到要迭代的物件,Iterator會
丟擲java.util.ConcurrentModificationException異常。
    所以Iterator在工作的時候是不允許被迭代的物件被改變的。但可使用Iterator本身的remove()來刪除物件,Iterator.remove()
方法會在刪除當前迭代物件的同時保持索引的一致性。