通常我给每个人或实体或者任何名为isMarkedForDeletion的布尔字段.然后在主循环期间,它们将被告知更新(),或者如果它们被标记为删除,则它们的索引将被添加到删除列表中.删除列表全部填充后,您可以遍历删除列表并从主列表中删除这些对象.或者,您可以向后迭代并从列表的尾端拉出.
这可能会也可能不会解释你的ConcurrentModificationException – 我以前在使用ArrayList时从未得到它们.但是,我从LinkedList获得了它们,正是因为你描述的原因并且与线程无关.实际原因是使用迭代器.以下将导致ConcurrentModificationException:
for (Iterator i = list.iterator(); i.hasNext();)
{
Person o = i.next();
o.update();
if (list.isMarkedForDeletion())
{
list.remove(o);
}
}
这不会导致异常:
ArrayList deletedObjects = new ArrayList();
for (Iterator i = list.iterator(); i.hasNext();)
{
Person o = i.next();
o.update();
if (list.isMarkedForDeletion())
{
deletedObjects.add(o);
}
}
for (int i = 0; i < deletedObjects.size(); i++)
{
list.remove(deletedObjects.get(i));
}
也许最简单的方法,不会导致异常:
for (int i = list.size()-1; i >= 0; i--)
{
Person o = list.get(i);
if (o.isMarkedForDeletion())
{
list.remove(i);
}
else
{
o.update();
}
}