`
xinklabi
  • 浏览: 1560217 次
  • 性别: Icon_minigender_1
  • 来自: 吉林
文章分类
社区版块
存档分类
最新评论

迭代的同时删除元素导致java.util.ConcurrentModificationException异常问题及如何解决

    博客分类:
  • Java
 
阅读更多

List迭代并删除没有问题,Map迭代并使用map的remove会抛出异常,但如果使用iterator的remove不会出问题。

List<Integer> list = new ArrayList<Integer>();

list.add(1);

list.add(2);

list.add(3);

 

for(int i=0;i<list.size();i++){

if(list.get(i)%2 == 0)

list.remove(i);

}

System.out.println("list 通过下标遍历并删除");

for(int i=0;i<list.size();i++){

System.out.println(list.get(i));

}

 

 

List<Integer> list1 = new ArrayList<Integer>();

list1.add(1);

list1.add(2);

list1.add(3);

list1.add(4);

list1.add(5);

Iterator<Integer> it = list1.iterator();

System.out.println("list 通过迭代器遍历并删除");

while(it.hasNext()){

if(it.next()%2 == 0)

it.remove();

}

for(int j=0;j<list1.size();j++){

System.out.println(list1.get(j));

}

 

Map<String, String> map = new HashMap<String, String>();

map.put("a", "a");

map.put("b", "b");

map.put("c", "c");

Iterator<String> it1  = map.keySet().iterator();

String key = null;

System.out.println("map 通过迭代器遍历并删除");

for(;it1.hasNext();){

key = it1.next();

if(key.equals("b"))

map.remove(key);

}

 

list 通过下标遍历并删除

1

3

list 通过迭代器遍历并删除

1

3

5

map 通过迭代器遍历并删除

Exception in thread "main" java.util.ConcurrentModificationException

at java.util.HashMap$HashIterator.nextEntry(Unknown Source)

at java.util.HashMap$KeyIterator.next(Unknown Source)

at com.test.TestIterator.main(TestIterator.java:54)

 

 下面这段map迭代并删除元素只要使用iterator的删除就不会抛异常。

  1. import java.util.HashMap;  
  2. import java.util.Iterator;  
  3. import java.util.Map;  
  4.   
  5. public class HashMapTest {  
  6.    private static Map<Integer, String> map=new HashMap<Integer,String>();  
  7.       
  8.    /**  1.HashMap 类映射不保证顺序;某些映射可明确保证其顺序: TreeMap 类 
  9.     *   2.在遍历Map过程中,不能用map.put(key,newVal),map.remove(key)来修改和删除元素, 
  10.     *   会引发 并发修改异常,可以通过迭代器的remove(): 
  11.     *   从迭代器指向的 collection 中移除当前迭代元素 
  12.     *   来达到删除访问中的元素的目的。   
  13.     *   */   
  14.    public static void main(String[] args) {  
  15.         map.put(1,"one");  
  16.         map.put(2,"two");  
  17.         map.put(3,"three");  
  18.         map.put(4,"four");  
  19.         map.put(5,"five");  
  20.         map.put(6,"six");  
  21.         map.put(7,"seven");  
  22.         map.put(8,"eight");  
  23.         map.put(5,"five");  
  24.         map.put(9,"nine");  
  25.         map.put(10,"ten");  
  26.         Iterator<Map.Entry<Integer, String>> it = map.entrySet().iterator();  
  27.         while(it.hasNext()){  
  28.             Map.Entry<Integer, String> entry=it.next();  
  29.             int key=entry.getKey();  
  30.             if(key%2==1){  
  31.                 System.out.println("delete this: "+key+" = "+key);  
  32.                 //map.put(key, "奇数");   //ConcurrentModificationException  
  33.                 //map.remove(key);      //ConcurrentModificationException  
  34.                 it.remove();        //OK   
  35.             }  
  36.         }  
  37.         //遍历当前的map;这种新的for循环无法修改map内容,因为不通过迭代器。  
  38.         System.out.println("-------\n\t最终的map的元素遍历:");  
  39.         for(Map.Entry<Integer, String> entry:map.entrySet()){  
  40.             int k=entry.getKey();  
  41.             String v=entry.getValue();  
  42.             System.out.println(k+" = "+v);  
  43.         }  
  44.     }  
  45. }  
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics