关闭

ConcurrentModificationException

110人阅读 评论(0) 收藏 举报
分类:
最近写代码竟然烦了一个很低级的错误,写出来供大家参考:
在涉及到map或者list删除的时候,我们经常写出如下错误代码:
LinkedHashMap<String,String> lhm=new LinkedHashMap<String,String>();
		lhm.put("a","a");
		lhm.put("b","b");
		lhm.put("c","c");
		lhm.put("d","d");
		Iterator<String> it=lhm.keySet().iterator();
while(it.hasNext())
{
   String str=it.next();
   if("a".equals(str))
       lhm.remove(str);
}

结果编译器报错Exception in thread "main" java.util.ConcurrentModificationException

正确代码如下:
LinkedHashMap<String,String> lhm=new LinkedHashMap<String,String>();
		lhm.put("a","a");
		lhm.put("b","b");
		lhm.put("c","c");
		lhm.put("d","d");
		Iterator<String> it=lhm.keySet().iterator();
while(it.hasNext())
{
   String str=it.next();
   if("a".equals(str))
       it.remove(str);
}



仅仅相差一个it.remove(str),你是不是也经常马虎呢?
其实,Iterator可以理解为一个索引,他依靠在其所要迭代的集合上,一旦使用lhm.remove,就会使原来的集合结构遭到破坏,此时原来的集合与iterator的索引结构不一致,自然iterator就会报错。而用iteraotr.remove(),iterator会自动的维护被迭代集合的索引一致性,因此能够正常运行。
0
0

  相关文章推荐
查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:112638次
    • 积分:1313
    • 等级:
    • 排名:千里之外
    • 原创:137篇
    • 转载:10篇
    • 译文:0篇
    • 评论:23条
    最新评论