- ArrayList的插入或删除一定慢吗?
- 取决于插入或删除的元素距离有多远,如果不是最后一个元素,则在插入或者删除时,需要移动该位置往后的元素,
- 在插入时且在数组的末端,如果底层数组的容量已经小于当前list容量,则根据ArrayList的扩容机制需要增大1.5倍的容量,并初始化一个新的数组,将原有的数据复制到新的数组中去,比较耗费资源,如果不是末端,还需要移动该位置之后的元素。
- 所以在集合里面插入元素速度比对结果是,首部插入,LinkedList更快;中间和尾部插入,ArrayList更快;在集合里面删除元素类似,首部删除,LinkedList更快;中间删除和尾部删除,ArrayList更快;由此建议,数据量不大的集合,主要进行插入、删除操作,建议使用LinkedList;数据量大的集合,使用ArrayList就可以了,不仅查询速度快,并且插入和删除效率也相对较高。
-
ArrayList的默认数组大小为什么是10?
据说是因为sun的程序员对一系列广泛使用的程序代码进行了调研,结果就是10这个长度的数组是最常用的最有效率的。也有说就是随便起的一个数字,8个12个都没什么区别,只是因为10这个数组比较的圆满而已 - ArrayList底层就是数组,访问速度本身就比较快,为什么还要实现RandomAccess接口?RandomAccess是一个标记接口
- (Marker interface), 被用于List接口的实现类, 表明这个实现类支持快速随机访问功能(如ArrayList). 当程序在遍历这中List的实现类时, 可以根据这个标识来选择更高效的遍历方式
- ArrayList是如何自动增加的?
- 当给ArrayList增加一个对象时,首先会检查该ArrayList是否有足够的容量来存储这个新对象,如果没有足够的容量时,会建一个新的更长的数组,是旧数组容量的1.5倍,旧的数组会使用Arrays.copyOf方法被复制到新的数组中去。现有的数组引用指向新的数组。
- 如何把一个ArrayList复制到另一个ArrayList中去?
- clone()方法:ArrayList newArray = oldArray.clone();
- 使用ArrayList构造方法,比如:ArrayList myObject = new ArrayList(myTempObject);
- 使用Collection的copy方法。
- 使用Arrays.copyOf()方法
-
ArrayList<Integer> arrayList = new ArrayList<>(20)中list的扩充了几次?
- 默认ArrayList的长度是10个,所以如果你要往list里添加20个元素肯定要扩充一次(newCapacity 扩充为原来的1.5倍,但和输入的minCapacity相比发现小于minCapacity,于是 newCapacity = minCapacity,所以只扩容一次,具体见扩容里的grow方法),但是这里显示指明了需要多少空间,所以就一次性为你分配这么多空间,也就是不需要扩充了