java中ArrayList和LinkedList的区别详解
arraylist和linkedlist都实现了list接口,有以下的不同点:
1、arraylist是基于索引的数据接口,它的底层是数组。它可以以o(1)时间复杂度对元素进行随机访问。与此对应,linkedlist是以元素列表的形式存储它的数据,每一个元素都和它的前一个和后一个元素链接在一起,在这种情况下,查找某个元素的时间复杂度是o(n)。
2、相对于arraylist,linkedlist的插入,添加,删除操作速度更快,因为当元素被添加到集合任意位置的时候,不需要像数组那样重新计算大小或者是更新索引。
3、linkedlist比arraylist更占内存,因为linkedlist为每一个节点存储了两个引用,一个指向前一个元素,一个指向下一个元素。
arraylist扩容:
总的来说就是分两步:
1、扩容
把原来的数组复制到另一个内存空间更大的数组中
2、添加元素
把新元素添加到扩容以后的数组中
无参构造:
public arraylist() { this.elementdata = defaultcapacity_empty_elementdata; }
带参构造:
public arraylist(int initialcapacity) { if (initialcapacity >0) { this.elementdata =new object[initialcapacity]; }else if (initialcapacity ==0) { this.elementdata = empty_elementdata; }else { throw new illegalargumentexception("illegal capacity: "+ initialcapacity); } }
在无参构造中,我们看到了在用无参构造来创建对象的时候其实就是创建了一个空数组,长度为0
在有参构造中,传入的参数是正整数就按照传入的参数来确定创建数组的大小,否则异常
接下来我们来看扩容,扩容的方法就是 add(e e)
public boolean add(e e) { ensurecapacityinternal(size + 1); // increments modcount!! elementdata[size++] = e; return true; }
private void ensurecapacityinternal(int mincapacity) { ensureexplicitcapacity(calculatecapacity(elementdata, mincapacity)); }
private static int calculatecapacity(object[] elementdata, int mincapacity) { if (elementdata == defaultcapacity_empty_elementdata) { return math.max(default_capacity, mincapacity); } return mincapacity; }
private void ensureexplicitcapacity(int mincapacity) { modcount++; // overflow-conscious code if (mincapacity - elementdata.length > 0) grow(mincapacity); }
private void grow(int mincapacity) { // overflow-conscious code int oldcapacity = elementdata.length; int newcapacity = oldcapacity + (oldcapacity >> 1); if (newcapacity - mincapacity < 0) newcapacity = mincapacity; if (newcapacity - max_array_size > 0) newcapacity = hugecapacity(mincapacity); // mincapacity is usually close to size, so this is a win: elementdata = arrays.copyof(elementdata, newcapacity); }
int newcapacity = oldcapacity + (oldcapacity >> 1);
oldcapacity >> 1 右移运算符 原来长度的一半 再加上原长度也就是每次扩容是原来的1.5倍
之前的所有都是确定新数组的长度,确定之后就是把老数组copy到新数组中,这样数组的扩容就结束了
以上的一切都是arraylist扩容的第一步,第二步就没啥说的了,就是把需要添加的元素添加到数组的最后一位
以上就是java中arraylist和linkedlist的区别详解的详细内容,更多关于java arraylist和linkedlist的区别的资料请关注其它相关文章!
上一篇: 详解Mybatis的缓存
下一篇: 详解Android的四大应用程序组件
推荐阅读
-
Java中增强for循环的实现原理和坑详解
-
java中静态变量和实例变量的区别详细介绍
-
浅谈Java异常的Exception e中的egetMessage()和toString()方法的区别
-
Java中HashMap和TreeMap的区别深入理解
-
java中重载、覆盖和隐藏三者的区别分析
-
java中instanceof和getClass()的区别分析
-
详解Java中HashSet和TreeSet的区别
-
java中timer的schedule和scheduleAtFixedRate方法区别详解
-
Java中关于int和Integer的区别详解
-
详解HTML5中div和section以及article的区别