数据结构

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毫秒
View Code

 

 

参考文献:https://blog.csdn.net/wjw89/article/details/132594299

posted on 2019-08-06 20:56  colorfulworld  阅读(154)  评论(0)    收藏  举报