您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

从多个线程修改时,为什么ArrayList不抛出ConcurrentModificationException?

从多个线程修改时,为什么ArrayList不抛出ConcurrentModificationException?

ArrayList为了您的利益,我引用了Javadoc 的很大一部分。突出显示解释您所看到的行为的相关部分。

。(结构修改添加删除一个或多个元素或显式调整后备数组大小的任何操作;仅设置元素的值不是结构修改。)这通常是通过对自然封装了对象的某些对象进行同步来实现的。清单。如果不存在这样的对象,则应使用Collections.synchronizedList方法“包装”列表。最好在创建时完成此操作,以防止意外的不同步访问列表:

列表列表= Collections.synchronizedList(new ArrayList(…));

此类的迭代器和listIterator方法返回的迭代器是快速失败的:如果在创建迭代器之后的任何时间以任何方式对列表进行结构修改,除非通过迭代器自己的remove或add方法,否则迭代器将抛出ConcurrentModificationException。因此,面对并发修改,迭代器将快速而干净地失败,而不是冒着在未来不确定的时间冒任意,不确定行为的风险。

快速失败的迭代器会尽最大努力抛出ConcurrentModificationException。因此,编写依赖于此异常的程序的正确性是错误的:迭代器的快速失败行为应仅用于检测错误

如果 列表时进行结构上的修改,则ArrayList通常会引发并发修改异常(但是,这并不是绝对的保证)。请注意,在您的示例中,您将直接从列表中删除元素,并且没有使用迭代器。

如果您喜欢它,也可以浏览的实现ArrayList.remove,以更好地了解它的工作方式。

其他 2022/1/1 18:30:59 有482人围观

撰写回答


你尚未登录,登录后可以

和开发者交流问题的细节

关注并接收问题和回答的更新提醒

参与内容的编辑和改进,让解决方法与时俱进

请先登录

推荐问题


联系我
置顶