今天在开发过程中遇到一个异常叫ConcurrentModificationException,这个异常用我的白话翻译是叫同时修改异常。
这个异常是怎么出现的呢,先看看已下的代码:
@Override
public void onGetModel(List<Model> modelList) {
if (modelList != null) {
this.indexModelList.addAll(modelList);
for (Model model1 : indexModelList) {
if (model1.getIsStart() != 1) {
indexModelList.remove(model);
}
}
mIndexModelAdapter.notifyDataSetChanged();
}
}
这是网络请求后得到数据集合,然后添加到成员变量的集合中,然后在通过getIsStart()方法来匹配处理不需要的数据,然后在刷新适配器。咋一看好像逻辑没毛病,但是运行起来就出现了ConcurrentModificationException。
这就是你在操作这个对象的同时又去做另外一个操作,打个比方就是银行里你存了100块钱,你去取50块钱,这是在操作这个100块钱的对象,然后你媳妇又在同时去存50块钱,那这样她也在操作这100块钱的对象,所以就出现了问题,肯定是要操作完了才能做其他的操作吧。
解决这个现象的方法有:
1.加同步锁,意思就是你在操作这个对象的时候其他地方是不能操作的非得等你操作完了才能操作。(意思就是你先来取50块钱的时候,银行把这个对象锁起来了,这时候你媳妇去取钱他就得等你取完才能轮到她取,也就是操作这个对象)。
2.创建一个新的对象来操作:
@Override
public void onGetModel(List<Model> modelList) {
if (modelList != null) {
List<Model> newModelList = new ArrayList<>();
for (Model model1 : modelList) {
if (model1.getIsStart() == 1) {
newModelList.add(model1);
}
}
this.indexModelList.addAll(newModelList);
}
mIndexModelAdapter.notifyDataSetChanged();
}
这样也就规避了对一个对象进行同时操作的情况。