【转载】ArrayList 中数据删除

简介:

本文转载自http://shift-alt-ctrl.iteye.com/blog/1839147

 

在循环arrayLlist时,经常会遇到remove操作,那么arrayList的remove的底层是怎么做的?

AbstractList中,有一个属性modCount,这个属性是跟踪list中数据被修改的次数,任何对list的add/remove操作,都将导致modCount++.

在AbstractList中还有一个内部类Itr implements Iterator,Itr是一个list遍历的工具类,当然list.iterator()方法也是返回Itr对象,在Itr中有一个校验位属性expectedModCount;对于一个itr对象,其初始时expectedModCount=modCount.

Iterator是list一个视图,其最终还是操作list的存储结构.在使用iterator遍历时,remove()操作,会导致modCount++(AbstractList.remove()),但是还有expectedModCount=modCount,即在iterator中remove数据,会带来expectedModCount与modCount值的同步.

在Iterator遍历时,next(),remove()方法会校验expectedModCount与modCount值是否一致,如果不一致,就意味着这list数据在iterator外部被修改,此时iterator遍历将会造成ConcurrentModificationException.

 

AbstractLlist不仅支持普通的iterator,还支持ListIterator(ArrayList,LinkedList均支持),ListIterator增加了遍历时双向游标能力(previous,next),增加了add方法.add方法和remove方法一样也做了expectedModCount和modCount一致性校验.

 引申一下,如下四个对list数据删除的代码,有区别吗??

如下是4中循环方式:

1) for(int i=0;i<list.size();i++){

list.remove(i);

}

2) for(int i=list.size()-1;i>=0;i--){

list.remove(i);

}

3)

int size = list.size();

for(int i=size-1;i>-1;i--){

list.remove(i);

}

 

4) for(Object i : list){

list.remove(i);//如果list中存在多个Object互相equals时,此方法仍然有效.注意list.remove(Object)内部使用了遍历操作,并使用equals来比较对象并删除.

}

5) Iterator it = list.iterator()

while(it.hasNext()){

it.next();

it.remove();

}

 

1),2),3)是最普通的遍历方式,但是在遍历并有删除操作时,似乎它们执行的结果还有些差距,根据坐标删除,那么1)实事上只会有一半被删掉,1)中每删除一次,计算一次list.size(),但是当前i++,且前端删除会造成数组结构copy.

2)后端删除,不会造成copy,每次都是删除最后一个位置,直至结束

3)因为size没有重新计算,在删除一半数据后,抛出IndexOutOfBoundsException

4)/5)正常

 

提示:foreach方式最终是转换成了iterator的方式进行.(产生于编译过程中).

目录
相关文章
|
2月前
|
存储 安全 Java
32.C#:ArrayList集合
32.C#:ArrayList集合
16 1
|
5月前
|
C#
C# 集合(ArrayList)的方法和使用
C# 集合(ArrayList)的方法和使用
|
9月前
|
安全
List和ArrayList的区别
List和ArrayList的区别
46 0
|
10月前
|
存储 算法
|
11月前
|
Java
ArrayList与LinkedList遍历方式对比及List遍历技巧
ArrayList与LinkedList遍历方式对比及List遍历技巧
56 0
|
11月前
|
存储
Arraylist存储学生对象并遍历
Arraylist存储学生对象并遍历
81 0
76. List如何一边遍历,一边删除
76. List如何一边遍历,一边删除
120 0
76. List如何一边遍历,一边删除
|
安全 Java 容器
如何在遍历的同时删除ArrayList 中的元素
如何在遍历的同时删除ArrayList 中的元素
352 0
ArrayList的remove()方法解读
remove()方法:要注意在remove()方法有两种形式: ①:remove(int index):按照集合下表查找,这个也是默认的,返回值是Object型。 ②:remove(Object o):按照value值进行移除操作涉及装箱,所以默认是第一种,其返回值是boolean型,表示操作是否成功。 remove(int index): @Test public void test1() { ArrayList arrayList...
142 0
ArrayList的remove()方法解读