java.util.ConcurrentModificationException 解決辦法
前言:
在使用iterator.hasNext()操作迭代器的時(shí)候,如果此時(shí)迭代的對象發(fā)生改變,比如插入了新數(shù)據(jù),或者有數(shù)據(jù)被刪除。
則使用會報(bào)以下異常:
1
2
3
|
Java.util.ConcurrentModificationException at java.util.HashMap$HashIterator.nextEntry(HashMap.java: 793 ) at java.util.HashMap$KeyIterator.next(HashMap.java: 828 ) |
例如以下程序(轉(zhuǎn)自互聯(lián)網(wǎng)):
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做遍歷的時(shí)候,HashMap被修改(bb.remove(ele), size-1),Iterator(Object ele=it.next())會檢查HashMap的size,size發(fā)生變化,拋出錯(cuò)誤ConcurrentModificationException。
解決辦法:
1) 通過Iterator修改Hashtable
1
2
3
4
|
while (it.hasNext()) { Object ele = it.next(); it.remove(); } |
2) 根據(jù)實(shí)際程序,您自己手動給Iterator遍歷的那段程序加鎖,給修改HashMap的那段程序加鎖。
3) 使用“ConcurrentHashMap”替換HashMap,ConcurrentHashMap會自己檢查修改操作,對其加鎖,也可針對插入操作。
1
|
import java.util.concurrent.*; |
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
原文鏈接:http://blog.csdn.net/lipei1220/article/details/9028669