ArrayList和LinkedList是Java Lis接口的2个实现。它们的区别如下表所示:

底层结构

强项

弱项

ArrayList

数组

随机访问get和set

插入删除

LinkedList

链表

插入删除

随机访问get和set

  那么它们在不同场景中的性能究竟有多大差别,我们来实测一下。

  测试环境:联想G50-70/INTEL CORE I7-4510U 双核4线程/WIN8.1 64bit。

  测试程序:ListPerformanceTest.java

  

package Colloections;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.LinkedList;
import java.util.List; public class ListPerformanceTest { public static void main(String[] args) {
// TODO Auto-generated method stub
ListPerformanceTest listPerformanceTest = new ListPerformanceTest();
listPerformanceTest.LinkedListPerformanceTest(50000);
listPerformanceTest.arrayListPerformanceTest(50000);
} public void listPerformanceTest(List<Integer> list){
int size = list.size();
long startTime = System.currentTimeMillis();
for (int i = 0; i < size; i++) {
list.get(i);
}
System.out.printf("%s: get element cost %d ms.%n", list.getClass().toString(), System.currentTimeMillis() - startTime);
startTime = System.currentTimeMillis();
for (int i = 0; i < size; i++) {
list.add(size, i);//add a element at designated position
}
System.out.printf("%s: add element cost %d ms.%n",list.getClass().toString(), System.currentTimeMillis() - startTime);
} public void LinkedListPerformanceTest(int size){
List<Integer> linkedList = new LinkedList<Integer>(createIntegerList(size));
listPerformanceTest(linkedList);
} public void arrayListPerformanceTest(int size){
List<Integer> arrayList = new ArrayList<Integer>(createIntegerList(size));
listPerformanceTest(arrayList);
} public List<Integer> createIntegerList(int size){
//construct a Integer list, but it is not a arrayList,is not allowed to add(),remove,etc
Integer [] array = new Integer[size];
for (int i = 0; i < size; i++) {
array[i] = i;
}
return Arrays.asList(array);
}
}

  输出如下:

  class java.util.LinkedList: get element cost 936 ms.

  class java.util.LinkedList: add element cost 2244 ms.

  class java.util.ArrayList: get element cost 1 ms.

  class java.util.ArrayList: add element cost 186 ms.

咦,不是说LinkedList对于插入删除操作很快么,为什么测出来还要比arrayList慢那么多?

仔细看listPerformanceTest函数,我们将其中的add方法调用进行如下修改:

for (int i = 0; i < size; i++) {
list.add(0, i);//add a element at designated position
}

  输出如下:

  class java.util.LinkedList: get element cost 940 ms.

  class java.util.LinkedList: add element cost 5 ms.

  class java.util.ArrayList: get element cost 1 ms.

  class java.util.ArrayList: add element cost 641 ms.

  这个结果与表1就吻合了。测试结果表明,LinkedList进行add操作时,其性能与元素所在的位置有很大关系。由于链表无法进行随机访问,因此操作指定位置的元素时,都必须从首元素开始遍历,也就是说,如果指定元素的位置越靠后,则操作越耗时,越靠前则越省时。当然,remove操作也是一样的。因此,ArrayList与LinkedList的性能孰优孰劣不能一概而论,要视具体元素的分布而定。Java Tutorial原文写道:如果你决定使用LinkedList,在做决定之前请使用ArrayList和LinkedList分别测试你的应用程序,一般ArrayList要更快一些。

ArrayList和LinkedList区别及性能测试的更多相关文章

  1. String[]和ArrayList和LinkedList区别

    String[]和ArrayList和LinkedList区别 参考文档如下: http://www.blogjava.net/flysky19/articles/92775.html http:// ...

  2. 一、基础篇--1.2Java集合-Arraylist 与 LinkedList 区别

     Arraylist 与 LinkedList 区别  结构上的区别 ArrayList底层实现基于动态数组,LinkedList底层实现基于双向链表.  性能上区别 ArrayList查询快,增删慢 ...

  3. 1.ArrayList和LinkedList区别

    说⼀下ArrayList和LinkedList区别 具体区别 1.1. ⾸先,他们的底层数据结构不同,ArrayList底层是基于数组实现的,LinkedList底层是基于链表实现的 1.2. 由于底 ...

  4. Java中ArrayList和LinkedList区别

    ArrayList和LinkedList的大致区别如下:1.ArrayList是实现了基于动态数组的数据结构,LinkedList基于链表的数据结构. 2.对于随机访问get和set,ArrayLis ...

  5. 简谈ArrayList和LinkedList区别

    对于ArrayList和LinkedList,他们都实现了List接口,他们的区别大致为: ArrayList LinkedList (1)底层是数组,可以以O(1)的时间复杂度对元素进行随机访问 以 ...

  6. ArrayList和LinkedList区别

    一般大家都知道ArrayList和LinkedList的大致区别:      1.ArrayList是实现了基于动态数组的数据结构,LinkedList基于链表的数据结构.      2.对于随机访问 ...

  7. Java中ArrayList和LinkedList区别 时间复杂度 与空间复杂度

    一般大家都知道ArrayList和LinkedList的大致区别:      1.ArrayList是实现了基于动态数组的数据结构,LinkedList基于链表的数据结构.      2.对于随机访问 ...

  8. Java中ArrayList和LinkedList区别、ArrayList和Vector的区别

    一般大家都知道ArrayList和LinkedList的大致区别: 1.ArrayList是实现了基于动态数组的数据结构,LinkedList基于链表的数据结构. 2.对于随机访问get和set,Ar ...

  9. ArrayList和LinkedList区别(蚂蚁金服面试题)

    1. 是否保证线程安全: ArrayList 和 LinkedList 都是不同步的,也就是不保证线程安全: 2. 底层数据结构: Arraylist 底层使用的是Object数组:LinkedLis ...

随机推荐

  1. 十分钟帮你搭建专业的内容付费平台(APP/网站)

    内容付费变现时代,从商业运营角度出发,全面付费系统多方面支付节点,强化优质付费价格核心,ThinkSNS+(简称TS+),专注于帮助创业者变现,抓取社群经济,让您拥有专属的知识变现软件系统. 一.内容 ...

  2. 在Eclipse下运行Jmeter3.0源代码

    1.创建项目 准备工作:在http://jmeter.apache.org/download_jmeter.cgi中分别下载binaries和source两个压缩包,前者为release版本,后者则为 ...

  3. html table中单元格自动换行

    table中单元格自动换行样式: table-layout: fixed; word-wrap: break-word;   table-layout 可能的值(IE不支持inherit属性) 值 描 ...

  4. 【秒懂】号称最为简明实用的Django上手教程(下)

    号称最为简明实用的Django上手教程(下) 作者:白宁超 2017年8月25日08:51:58 摘要:上文号称[最为简明实用的Django上手教程]介绍了django基本概念.配置和相关操作.相信通 ...

  5. /etc/fstab最后3个字段详解

    /etc/fstab文件的作用就是让挂载的信息在开启的时候生效: 磁盘分区 挂载目录 文件格式 访问方式 fs_dump fs_pass /dev/sdb1 /mnt ext4 defaults   ...

  6. 【Linux】添加sudo用户、sudo用戶組

    sudo权限在super和普通用户之间,既不因为操作失误带来麻烦,也可以在必要时发挥管理员权限,适合于系统管理员使用. 给一个普通用户添加sudo权限步骤: 1. su进入超级用户模式 . 2.添加文 ...

  7. [js高手之路]面向对象+设计模式+继承一步步改造简单的四则运算

    到目前为止,我已经写完了面向对象完整的一个系列知识,前面基本属于理论,原理的理解,接下来,我们就用学到的知识来实战下吧. 看看理解原理和理论是否重要?例子从简单到复杂 一.单体(字面量)封装加减乘除 ...

  8. Java开源连接池c3p0的基本用法

    前言:其实c3p0只是一个实现了javax.sql 接口 DataSource的一个工具集,使用c3p0可以帮我们管理宝贵的Connection资源,无须我们去创建连接(免去每次配置数据库驱动,url ...

  9. SQL优化工具

    SQL优化工具 什么是索引? 打个比方,我们在使用MySQL用作查询的时候就好比查字典,索引就好比字典的偏旁部首页.如果没有索引我们查询一个文字就需要一页页的翻,显然这种方式效率很低.如果我们对某一字 ...

  10. PHP文件操作整理

    三种目录表示: ./     代表当前目录 ../    代表父级目录 /   代表根目录 常用的文件操作函数有 通用读写:                  fpen()  fwrite() fre ...