java.util.ConcurrentModificationException 解決辦法
前言:
在使用iterator.hasNext()操作迭代器的時候,如果此時迭代的對象發生改變,比如插入了新數據,或者有數據被刪除。
則使用會報以下異常:
1
2
3
|
Java.util.ConcurrentModificationException at java.util.HashMap$HashIterator.nextEntry(HashMap.java: 793 ) at java.util.HashMap$KeyIterator.next(HashMap.java: 828 ) |
例如以下程序(轉自互聯網):
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
mport java.util.*; public class Main { public static void main(String args[]) { Main main = new Main(); main.test(); } public void test() { Map bb = new HashMap(); bb.put( "1" , "wj" ); bb.put( "2" , "ry" ); Iterator it = bb.keySet().iterator(); while (it.hasNext()) { Object ele = it.next(); bb.remove(ele); //wrong } System.out.println( "Success!" ); } } |
原因:Iterator做遍歷的時候,HashMap被修改(bb.remove(ele), size-1),Iterator(Object ele=it.next())會檢查HashMap的size,size發生變化,拋出錯誤ConcurrentModificationException。
解決辦法:
1) 通過Iterator修改Hashtable
1
2
3
4
|
while (it.hasNext()) { Object ele = it.next(); it.remove(); } |
2) 根據實際程序,您自己手動給Iterator遍歷的那段程序加鎖,給修改HashMap的那段程序加鎖。
3) 使用“ConcurrentHashMap”替換HashMap,ConcurrentHashMap會自己檢查修改操作,對其加鎖,也可針對插入操作。
1
|
import java.util.concurrent.*; |
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
原文鏈接:http://blog.csdn.net/lipei1220/article/details/9028669