博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java中ArrayList学习笔记
阅读量:5236 次
发布时间:2019-06-14

本文共 1104 字,大约阅读时间需要 3 分钟。

1. 先看两段代码

这段代码在执行的时候会报

但是这样写就好着呢:

总结,研究报错的代码 ,在for循环的时候调用next()方法,next方法中调用了checkForComodification这个方法,这个方法里面判断modCount和expectedModCount不相等的时候就抛出ConcurrentModificationException这个异常。

原因:当for循环执行的时候首先调用了

这个方法,这个方法初始化了expectedModCount=modCount,modCount的值是在add方法里面复制的,如当前程序为8,初始化给expectedModCount的值。当调用remove 方法的时候,将modCount++; 导致下一次循环的时候两个值不相同,就会报这个错误。

这里还有个知识点:

modCount 这个变量被transient关键字修饰,意思是不可被序列化。

参考文档:

2. 解决办法:

for (int i = students.size() - 1; i >= 0; i--) {
if (students.get(i).equals("李四")) {
students.remove(i); } } 注意倒叙删除。正序删除的时候由于size一直变小,可能后面的删除不了。
Iterator
iterator = students.iterator(); while (iterator.hasNext()) {
if (iterator.next().equals("李四")) iterator.remove(); } 用iterator的remove方法可以删除,因为remove方法中将expectedModCount=modCount。

 

2. 多线程问题

这段代码在执行的时候有时候会报错,就是在方法内部调用 next方法的时候expectedModCount和modCount的值不一致引起的。

解决方案:

用CopyOnWriteArrayList方法,注意这个方法没有实现iterator.remove()。CopyOnWriteArrayList 里面在操作数据都用Lock进行了处理,但是有个方法getArray()没有lock。

3.  ConcurrentHaspMap它也是线程安全的,它里面是通过synchronized实现的。

 

转载于:https://www.cnblogs.com/baoyi/p/java_arrayList.html

你可能感兴趣的文章
桥接模式-Bridge(Java实现)
查看>>
网络请求返回HTTP状态码(404,400,500)
查看>>
Spring的JdbcTemplate、NamedParameterJdbcTemplate、SimpleJdbcTemplate
查看>>
Mac下使用crontab来实现定时任务
查看>>
303. Range Sum Query - Immutable
查看>>
图片加载失败显示默认图片占位符
查看>>
【★】浅谈计算机与随机数
查看>>
解决 sublime text3 运行python文件无法input的问题
查看>>
javascript面相对象编程,封装与继承
查看>>
Atlas命名空间Sys.Data下控件介绍——DataColumn,DataRow和DataTable
查看>>
Java中正则表达式的使用
查看>>
算法之搜索篇
查看>>
新的开始
查看>>
java Facade模式
查看>>
NYOJ 120校园网络(有向图的强连通分量)(Kosaraju算法)
查看>>
Leetcode 226: Invert Binary Tree
查看>>
http站点转https站点教程
查看>>
解决miner.start() 返回null
查看>>
bzoj 2007: [Noi2010]海拔【最小割+dijskstra】
查看>>
BZOJ 1001--[BeiJing2006]狼抓兔子(最短路&对偶图)
查看>>