数据结构
ArrayList是数组,且是动态数组,因为ArrayList有自己的动态扩容机制,内存中存储是连续的。
LinkList是链表,且是双向链表,内存中存储是不连续的,因为是通过指针联系在一起。有头、尾节点。前一个元素的尾节点指向下一个元素的头节点,最后一个元素的尾节点指向第一个元素的头节点
因为ArrayList是通过下标查询数据,所以很快找到对应元素,而LinkList需要从头遍历。所以通常情况下ArrayList查询效率高;
因为ArrayList元素存储是连续的,如果遇到增删操作需要重排数据结构,这个过程耗费资源比较多,所以通常情况下ArrayList增删操作效率低;而LinkList只需要改变指针便可以实现增删,所以通常情况下LinkList增删效率高。
但以上只是通常情况!!!
数据查询
数据量在千万级别下,ArrayList和LinkList查询效率基本一样;
数据量在千万级别上,ArrayList查询效率要比Linklist高
数据插入
linkedlist是一个双向链表;而ArrayList是一个可变长数组
一般来说,插入和删除数据linkedlist效率要比arraylist高;


1、尾部插入元素时:①数据量在千万以下:linkedlist效率高,因为linkedlist有尾指针,linkedlist每次增加元素时会new一个node对象,数据量少时new出的node对象也少,arraylist扩容时间大于linkedlist 新建node时间,所以linkedlist效率高;②数据量在千万以上时,ArrayList效率高,因为linkedlist每次增加元素时会new一个node对象,数据量少时new出的node对象也少,但当数据量大后,new出的node对象相应增加,这样new node时间大于扩容时间,就会出现ArrayList效率比linkedlist高
2、插入/删除数据位置越往前,linkedlist效率比ArrayList高,因为linkedlist遍历插入位置花费时间少,而ArrayList需要将原数组所有元素后移进行一次数组复制
3、插入/删除数据位置越往中间,ArrayList效率比linkedlist高,因为linkedlist需要遍历查询中间位置比较浪费时间,所以慢一些
import java.util.*; public class Test { public static void main(String[] args) { ArrayList<Integer> List = new ArrayList<Integer>(); long start=System.currentTimeMillis(); for( int i=0;i <10000;i++ ) //给数组增加10个Int元素 List.add(i/2,i); System.out.println(System.currentTimeMillis()-start); //System.out.println(List); LinkedList<Integer> LList = new LinkedList<Integer>(); long startL=System.currentTimeMillis(); for( int i=0;i <10000;i++ ) //给数组增加10个Int元素 LList.add(i/2,i); System.out.println(System.currentTimeMillis()-startL); //System.out.println(LList); } } 结果: ArrayList 19毫秒 LinkList 129毫秒
参考文献:https://blog.csdn.net/wjw89/article/details/132594299
浙公网安备 33010602011771号