(自己转)比较ArrayList、LinkedList、Vector
1. List概述

- public static void testArrayList() {
- ArrayList<Integer> al = new ArrayList<Integer>();
- al.add(3);
- al.add(2);
- al.add(1);
- al.add(4);
- al.add(5);
- al.add(6);
- al.add(6);
- Iterator<Integer> iter1 = al.iterator();
- while(iter1.hasNext()){
- System.out.println(iter1.next());
- }
- }
- public static void testLinkedList() {
- LinkedList<Integer> ll = new LinkedList<Integer>();
- ll.add(3);
- ll.add(2);
- ll.add(1);
- ll.add(4);
- ll.add(5);
- ll.add(6);
- ll.add(6);
- Iterator<Integer> iter2 = ll.iterator();
- while(iter2.hasNext()){
- System.out.println(iter2.next());
- }
- }
| ArrayList | LinkedList | |
|---|---|---|
| get() | O(1) | O(n) |
| add() | O(1) | O(1) amortized |
| remove() | O(n) | O(n) |
* 表中的 add() 代表 add(E e),而 remove()代表 remove(int index)'
- ArrayList 对于随机位置的add/remove,时间复杂度为 O(n),但是对于列表末尾的添加/删除操作,时间复杂度是 O(1).
- LinkedList对于随机位置的add/remove,时间复杂度为 O(n),但是对于列表 末尾/开头 的添加/删除操作,时间复杂度是 O(1).
我使用下面的代码来测试他们的性能:
- public static void testPerformance() {
- ArrayList<Integer> arrayList = new ArrayList<Integer>();
- LinkedList<Integer> linkedList = new LinkedList<Integer>();
- int
- times = 10 * 1000;
- // times = 100 * 1000;
- // times = 1000 * 1000;
- System.out.println("Test times = " + times);
- System.out.println("-------------------------");
- // ArrayList add
- long startTime = System.nanoTime();
- for (int i = 0; i < times; i++) {
- arrayList.add(i);
- }
- long endTime = System.nanoTime();
- long duration = endTime - startTime;
- System.out.println(duration + " <--ArrayList add");
- // LinkedList add
- startTime = System.nanoTime();
- for (int i = 0; i < times; i++) {
- linkedList.add(i);
- }
- endTime = System.nanoTime();
- duration = endTime - startTime;
- System.out.println(duration + " <--LinkedList add");
- System.out.println("-------------------------");
- // ArrayList get
- startTime = System.nanoTime();
- for (int i = 0; i < times; i++) {
- arrayList.get(i);
- }
- endTime = System.nanoTime();
- duration = endTime - startTime;
- System.out.println(duration + " <--ArrayList get");
- // LinkedList get
- startTime = System.nanoTime();
- for (int i = 0; i < times; i++) {
- linkedList.get(i);
- }
- endTime = System.nanoTime();
- duration = endTime - startTime;
- System.out.println(duration + " <--LinkedList get");
- System.out.println("-------------------------");
- // ArrayList remove
- startTime = System.nanoTime();
- for (int i = times - 1; i >= 0; i--) {
- arrayList.remove(i);
- }
- endTime = System.nanoTime();
- duration = endTime - startTime;
- System.out.println(duration + " <--ArrayList remove");
- // LinkedList remove
- startTime = System.nanoTime();
- for (int i = times - 1; i >= 0; i--) {
- linkedList.remove(i);
- }
- endTime = System.nanoTime();
- duration = endTime - startTime;
- System.out.println(duration + " <--LinkedList remove");
- }
- Test times = 10000
- -------------------------
- 1469985 <--ArrayList add
- 3530491 <--LinkedList add
- -------------------------
- 593678 <--ArrayList get
- 86914251 <--LinkedList get
- -------------------------
- 625651 <--ArrayList remove
- 2164320 <--LinkedList remove
- Test times = 100000
- -------------------------
- 11480805 <--ArrayList add
- 26384338 <--LinkedList add
- -------------------------
- 714072 <--ArrayList get
- 10040809061 <--LinkedList get
- -------------------------
- 1203935 <--ArrayList remove
- 1595905 <--LinkedList remove
- 在 1000*1000次的运行中,很长时间过后, LinkedList的get日志还没有打印出来,大概是15分钟左右,结果还是没有出来.
- Test times = 1000000
- -------------------------
- 132632998 <--ArrayList add
- 322885939 <--LinkedList add
- -------------------------
- 3690752 <--ArrayList get
- 1520315361147 <--LinkedList get
- -------------------------
- 8750043 <--ArrayList remove
- 13872885 <--LinkedList remove
他们性能的差异相当明显,LinkedList在 add和remove 上更快,而在get上更慢(原文是这样的).
译者注: 译者的编译和执行环境是 MyEclipse的JDK6,不论怎么看,都是 ArrayList更胜一筹,所以,该怎么选择,请根据自己的实际情况来决定,最好自己做测试,因为数据类型不同,JDK版本不同,优化不同,就可能有不同的结果。
根据时间复杂度表格,以及测试结果,我们可以判断何时该用ArrayList,何时该用LinkedList.
- 没有大规模的随机读取
- 大量的增加/删除操作
(自己转)比较ArrayList、LinkedList、Vector的更多相关文章
- ArrayList LinkedList Vector
ArrayList是基于数组实现的,没有容量的限制. 在删除元素的时候,并不会减少数组的容量大小,可以调用ArrayList的trimeToSize()来缩小数组的容量. ArrayList, Lin ...
- ArrayList, LinkedList, Vector - dudu:史上最详解
ArrayList, LinkedList, Vector - dudu:史上最详解 我们来比较一下ArrayList, LinkedLIst和Vector它们之间的区别.BZ的JDK版本是1.7.0 ...
- java 中 ArrayList LinkedList Vector 三者的异同点
1.ArrayList和Vector都是基于数组实现的,所以查询速度很快,增加和删除(非最后一个节点)速度慢: Vector是线程安全的,ArrayList不是. 2.LinkedList 是一个双向 ...
- 集合类源码(二)Collection之List(ArrayList, LinkedList, Vector)
ArrayList 功能 完全命名 public class ArrayList<E> extends AbstractList<E> implements List<E ...
- ArrayList,LinkedList,Vector集合的认识
最近在温习Java集合部分,花了三天时间读完了ArrayList与LinkedList以及Vector部分的源码.之前都是停留在简单使用ArrayList的API,读完源码看完不少文章后总算是对原理方 ...
- ArrayList,LinkedList,vector的区别
1,Vector.ArrayList都是以类似数组的形式存储在内存中,LinkedList则以链表的形式进行存储. 2.List中的元素有序.允许有重复的元素,Set中的元素无序.不允许有重复元素. ...
- ArrayList LinkedList Vector之间的区别
List主要有ArrayList,LinkedList和vector三种实现.这三种都实现了List接口,使用方式也很相似,主要区别在于其实现方式的不同! 这三种数据结构中,ArrayList和Vec ...
- 比较Java数组,ArrayList,LinkedList,Vector 性能比较
public class PerformanceTester { public static final int TIMES=100000; public static abstract class ...
- hasSet,TreeSet,ArrayList,LinkedList,Vector,HashMap,HashTable,TreeMap利用Iterator进行输出
基础类,没有重写hashCode()和equals()方法: package niukewang; import java.util.Objects; public class setClass { ...
- java类集框架(ArrayList,LinkedList,Vector区别)
主要分两个接口:collection和Map 主要分三类:集合(set).列表(List).映射(Map)1.集合:没有重复对象,没有特定排序方式2.列表:对象按索引位置排序,可以有重复对象3.映射: ...
随机推荐
- 【学习笔记】dp入门
知识点 动态规划(简称dp),可以说是各种程序设计中遇到的第一个坎吧,这篇博文是我对dp的一点点理解,希望可以帮助更多人dp入门. 先看看这段话 动态规划(dynamic programming) ...
- Mysql Cluster节点类型(转载)
mysql 自4.1.x版本开始推出mysql cluster功能.cluster简单地说,就是一组"节点"的组合.这里的节点是一个逻辑概念,一台计算机上可以存放一个节点,也可以存 ...
- linux下启动关闭oracle
1. linux下启动oracle su - oracle sqlplus /nolog conn /as sysdba startup exit lsnrctl start 2. linux下关闭o ...
- 一些通用的触发移动App崩溃的测试场景
一些通用的触发移动App崩溃的测试场景,如下: 1 验证在有不同的屏幕分辨率,操作系统和运营商的多个设备上的App行为. 2 用新发布的操作系统版本验证App的行为. 3 验证在如隧道,电梯等网络质量 ...
- Windbg基本命令应用总结
.cordll -ve -u -l //reload core dlls ------加载下载系统文件符号的URL---------- .sympath SRV*C:\Symbols*http://m ...
- ffmpeg强制使用TCP方式读取rtsp流
ffmpeg强制使用TCP方式处理rtsp流,参考网上资料,得知可以使用如下命令: “ffmpeg -rtsp_transport tcp -i rtsp://admin.......” 可以是使用抓 ...
- UVALIVE 4556 The Next Permutation
4556 The Next PermutationFor this problem, you will write a program that takes a (possibly long) str ...
- 退出telnet 命令
很多时候 telnet 完就无法退出了,ctrl+c 有时也无法退出 后来找到了正确的命令 ctrl+] 然后在telnet 命令行输入 quit 就可以退出了
- @manyToOne.@oneToMany
@ManyToOne注解的这端,是多端 1.在注释@ManyToOne(cascade=CascadeType.REFRESH,optional=true)中将属性optional设置为true,这可 ...
- .net Core 2.0使用NLog
最近研究了一下NLog的使用方式,简单的入了一下门. 实现的功能,对于不同的日志,进行不同的记录,分别有系统运行日志,和个人在程序中写的异常日志.发布之后放在了IIS上.进行查看日志的信息 参考了两篇 ...