当前位置:  编程技术>java/j2ee

java中ArrayList 、LinkList的区别分析

    来源: 互联网  发布时间:2014-10-24

    本文导语:  1.ArrayList是实现了基于动态数组的数据结构,LinkedList基于链表的数据结构。      2.对于随机访问get和set,ArrayList优于LinkedList,因为ArrayList可以随机定位,而LinkedList要移动指针一步一步的移动到节点处。(参考数组与链表来...

1.ArrayList是实现了基于动态数组的数据结构,LinkedList基于链表的数据结构。
     2.对于随机访问get和set,ArrayList优于LinkedList,因为ArrayList可以随机定位,而LinkedList要移动指针一步一步的移动到节点处。(参考数组与链表来思考)
     3.对于新增和删除操作add和remove,LinedList比较占优势,只需要对指针进行修改即可,而ArrayList要移动数据来填补被删除的对象的空间。

ArrayList和LinkedList是两个集合类,用于存储一系列的对象引用(references)。例如我们可以用ArrayList来存储一系列的String或者Integer。那么ArrayList和LinkedList在性能上有什么差别呢?什么时候应该用ArrayList什么时候又该用LinkedList呢?

一.时间复杂度

首先一点关键的是,ArrayList的内部实现是基于基础的对象数组的,因此,它使用get方法访问列表中的任意一个元素时(random-access),它的速度要比LinkedList快。LinkedList中的get方法是按照顺序从列表的一端开始检查,直到另外一端。对LinkedList而言,访问列表中的某个指定元素没有更快的方法了。

假设我们有一个很大的列表,它里面的元素已经排好序了,这个列表可能是ArrayList类型的也可能是LinkedList类型的,现在我们对这个列表来进行二分查找(binary search),比较列表是ArrayList和LinkedList时的查询速度,看下面的程序:

代码如下:

package com.mangocity.test;
import java.util.LinkedList;
import java.util.List;
import java.util.Random;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
public class TestList ...{
     public static final int N=50000;
     public static List values;
     static...{
         Integer vals[]=new Integer[N];
         Random r=new Random();
         for(int i=0,currval=0;i

    
 
 

您可能感兴趣的文章:

  • java命名空间java.util类arraylist<e>的类成员方法: arraylist定义及介绍
  • java的arraylist排序示例(arraylist用法)
  • java命名空间java.util类arraylist<e>的类成员方法: clone定义及介绍
  • java中ArrayList的几个问题!
  • java命名空间java.util类arraylist<e>的类成员方法: ensurecapacity定义及介绍
  • 浅析java中ArrayList与Vector的区别以及HashMap与Hashtable的区别
  • java命名空间java.util类arraylist<e>的类成员方法: clear定义及介绍
  • java使用listIterator逆序arraylist示例分享
  • java命名空间java.util类arraylist<e>的类成员方法: size定义及介绍
  • <<Thingking in JAVA>>里的疑惑 :Vector 与 ArrayList
  • java命名空间java.util类arraylist<e>的类成员方法: isempty定义及介绍
  • Java中Vector与ArrayList的区别详解
  • java命名空间java.util类arraylist<e>的类成员方法: get定义及介绍
  • java教程之二个arraylist排序的示例分享
  • java命名空间java.util类arraylist<e>的类成员方法: add定义及介绍
  • Java中ArrayList类的使用方法
  • java命名空间java.util类arraylist<e>的类成员方法: set定义及介绍
  • JAVA LinkedList和ArrayList的使用及性能分析
  • java命名空间java.util类arraylist<e>的类成员方法: lastindexof定义及介绍
  • JAVA ArrayList详细介绍(示例)
  • java命名空间java.util类arraylist<e>的类成员方法: indexof定义及介绍
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 我想编程分析任意一个java文件,把其中的注释部分删掉,请帮我分析一下思路和方法好吗?
  • 急!请问有分析java程序性能瓶颈的工具吗?例如,统计 java 程序中函数调用次数?
  • Java 代码分析工具 JHawk
  • Java程序性能分析工具 VisualVM
  • Java 静态分析工具 JArchitect
  • Java监控和分析 Memory Analyzer
  • 基于Java的磁盘分析工具 JDiskReport
  • Java运行分析工具 jSonde
  • Java包依赖分析插件 ModelGoon
  • Java 网络数据分析包 JNetStream
  • Java多线程实时分析工具 mtrat
  • Java代码覆盖测试分析工具 Clover
  • Java内存使用分析 HeapAnalyzer
  • UIMA分析引擎 UIMA Java
  • Java程序性能分析工具 VisualVM iis7站长之家
  • 使用java如何分析系统不能识别的字符串?
  • Java动态跟踪分析工具 BTrace
  • Java代码Bug分析插件 FindBugs
  • Java文档分析工具 DoctorJ
  • Java包依赖分析 jDependency
  • java命名空间java.sql类types的类成员方法: java_object定义及介绍
  • 我想学JAVA ,是买THINK IN JAVA 还是JAVA2核心技术:卷1 好???
  • java命名空间java.awt.datatransfer类dataflavor的类成员方法: imageflavor定义及介绍
  • 请问Java高手,Java的优势在那里??,Java主要适合于开发哪类应用程序
  • java命名空间java.lang.management类managementfactory的类成员方法: getcompilationmxbean定义及介绍
  • 如何将java.util.Date转化为java.sql.Date?数据库中Date类型对应于java的哪个Date呢
  • java命名空间java.lang.management接口runtimemxbean的类成员方法: getlibrarypath定义及介绍
  • 谁有电子版的《Java编程思想第二版(Thinking in java second)》和《Java2编程详解(special edition java2)》?得到给分
  • java命名空间java.lang.management接口runtimemxbean的类成员方法: getstarttime定义及介绍
  • 本人想学java,请问java程序员的待遇如何,和java主要有几个比较强的方向
  • java命名空间java.awt.datatransfer类dataflavor的类成员方法: stringflavor定义及介绍




  • 特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3