请问java.util.ConcurrentModificationException怎么解决啊

部分代码:

01List<StationeryApplyDetail> listClass = Lists.newArrayList();
02  for(StationeryApplyDetail s : list){
03   if(listClass.size()!=0){
04    for(StationeryApplyDetail sa : listClass){
05     if(s.getStationeryID().getId()!=sa.getStationeryID().getId()){
06      listClass.add(s);
07     }
08    }
09   }else{
10    listClass.add(s);
11   }
12  }

我只知道是迭代出了问题,但不知道该怎样修改代码

01java.util.ConcurrentModificationException
02 at java.util.ArrayList$Itr.checkForComodification(Unknown Source)
03 at java.util.ArrayList$Itr.next(Unknown Source)
04 at com.esj.www.web.departmentofmanagent.PurchaseApplyMainAction.collect(PurchaseApplyMainAction.java:224)
05 at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
06 at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
07 at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
08 at java.lang.reflect.Method.invoke(Unknown Source)
09 at com.opensymphony.xwork2.DefaultActionInvocation.invokeAction(DefaultActionInvocation.java:452)
10 at com.opensymphony.xwork2.DefaultActionInvocation.invokeActionOnly(DefaultActionInvocation.java:291)
11 at com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:254)
0
红薯
不要用 for(xxx : xxx) 这种循环方式,用 for(int i=0;i<listClass.size();i++) 这种就没事
Java中的`ConcurrentModificationException`通常发生在多线程环境下,当一个集合(如ArrayList、LinkedList等)在遍历时被其他线程修改了其内容,这将导致异常抛出,因为集合内部的数据结构已经被破坏,无法继续迭代。要避免这种异常,可以采取以下几种策略: 1. **同步访问**:在遍历集合的同时锁定它,确保在遍历期间不会发生改变。例如,你可以使用`synchronized`关键字或更推荐的`Collections.synchronizedList()`方法来同步列表。 ```java synchronized(list) { for (Element element : list) { // ...处理元素... } } ``` 2. **Copy-on-write模式**:如果集合支持并发访问并允许安全的复制,如`CopyOnWriteArrayList`,可以在遍历时创建一个副本,然后在副本上操作,原集合不会受影响。 ```java CopyOnWriteArrayList<Element> copy = new CopyOnWriteArrayList<>(list); for (Element element : copy) { // ...处理元素... } ``` 3. **观察者模式**:使用`java.util.Observable`和`java.util.Observer`来通知数据变化,而不是直接修改。观察者可以在更新后自行决定是否需要重新遍历。 4. **使用`Iterator`的try-with-resources语句**:`Iterator`有一个`hasNext()`和`next()`方法组合,可以确保在遇到异常时自动关闭迭代器。 ```java Iterator<Element> iterator = list.iterator(); while (iterator.hasNext()) { try { Element element = iterator.next(); // ...处理元素... } catch (ConcurrentModificationException e) { break; // 或者记录错误并退出 } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值