iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Java中ArrayList、LinkedList、Vector、Stack的对比
  • 930
分享到

Java中ArrayList、LinkedList、Vector、Stack的对比

2023-06-16 17:06:45 930人浏览 泡泡鱼
摘要

本篇内容介绍了“Java中ArrayList、LinkedList、Vector、Stack的对比”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所

本篇内容介绍了“Java中ArrayList、LinkedList、Vector、Stack的对比”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

 一、介绍

先回顾一下List的框架

Java中ArrayList、LinkedList、Vector、Stack的对比

由图中的继承关系,可以知道,ArrayList、LinkedList、Vector、Stack都是List的四个实现类。

AbstractList是一个抽象类,它继承于AbstractCollection。AbstractList实现List接口中除size()、get(int  location)之外的函数。

AbstractSequentialList 是一个抽象类,它继承于AbstractList。AbstractSequentialList  实现了“链表中,根据index索引值操作链表的全部函数”。

ArrayList 是一个数组队列,相当于动态数组。它由数组实现,随机访问效率高,随机插入、随机删除效率低。

LinkedList 是一个双向链表。它也可以被当作堆栈、队列或双端队列进行操作。LinkedList随机访问效率低,但随机插入、随机删除效率低。

Vector  是矢量队列,和ArrayList一样,它也是一个动态数组,由数组实现。但是ArrayList是非线程安全的,而Vector是线程安全的。

Stack 是栈,它继承于Vector。它的特性是:先进后出(FILO, First In Last Out)。

二、性能测试

在对ArrayList、LinkedList、Vector、Stack进行比较之前,我们先来对他们进行一个性能测试,结合源码测试结果来对ArrayList、LinkedList、Vector、Stack进行详细的分析。

Java中ArrayList、LinkedList、Vector、Stack的对比
Java中ArrayList、LinkedList、Vector、Stack的对比

得到的结果如下

Java中ArrayList、LinkedList、Vector、Stack的对比

根据结果,可以很明显的看出ArrayList、LinkedList、Vector、Stack的性能有很大的区别。

Java中ArrayList、LinkedList、Vector、Stack的对比

读取:ArrayList > Vector > Stack > LinkedList

插入:LinkedList > Vector > ArrayList > Stack

删除:LinkedList > Vector > ArrayList > Stack

三、插入的分析

LinkedList

Java中ArrayList、LinkedList、Vector、Stack的对比

从中,我们可以看出:通过add(int index, E  element)向LinkedList插入元素时。先是在双向链表中找到要插入节点的位置index;找到之后,再插入一个新节点。

双向链表查找index位置的节点时,有一个加速动作:若index < 双向链表长度的1/2,则从前向后查找; 否则,从后向前查找。

ArrayList

Java中ArrayList、LinkedList、Vector、Stack的对比

在这里面有一个非常耗时的操作

System.arraycopy(elementData, index, elementData, index + 1, size -  index);

该方法被标记了native,调用了系统的C/C++代码,在jdk中是看不到的,但在openJDK中可以看到其源码。

该函数实际上最终调用了C语言的memmove()函数,因此它可以保证同一个数组内元素的正确复制和移动,比一般的复制方法的实现效率要高很多,很适合用来批量处理数组。Java强烈推荐在复制大量数组元素时用该方法,以取得更高的效率。

Vector

Java中ArrayList、LinkedList、Vector、Stack的对比

可以看到Vector和ArrayList是一样的,都调用了System.arraycopy。由于Stack和继承与Vector,就不仔细分析了。

四、查找的分析

LinkedList

Java中ArrayList、LinkedList、Vector、Stack的对比

从中,我们可以看出:通过get(int  index)获取LinkedList第index个元素时。先是在双向链表中找到要index位置的元素;找到之后再返回。

双向链表查找index位置的节点时,有一个加速动作:若index < 双向链表长度的1/2,则从前向后查找; 否则,从后向前查找。

ArrayList

Java中ArrayList、LinkedList、Vector、Stack的对比

我们可以看到ArrayList直接返回数组中index位置的元素,而不需要像LinkedList一样进行查找。

通过源码发现Vector和Stack的操作方式和ArrayList一样,这里就不详细分析了。

五、删除的分析

LinkedList

Java中ArrayList、LinkedList、Vector、Stack的对比

由于删除了某一节点因此调整相应节点的前后指针信息,如下:

e.previous.next = e.next;//预删除节点的前一节点的后指针指向预删除节点的后一个节点。  e.next.previous = e.previous;//预删除节点的后一节点的前指针指向预删除节点的前一个节点。

清空预删除节点:

e.next = e.previous = null; e.element = null;

交给GC完成资源回收,删除操作结束。

与ArrayList比较而言,LinkedList的删除动作不需要“移动”很多数据,从而效率更高。

ArrayList

Java中ArrayList、LinkedList、Vector、Stack的对比

恩,又是调用了System.arraycopy。

六、结论

操作ArrayListLinkedListVectorStack读取O(1)O(n)O(1)O(1)插入O(n)O(1)O(n)O(n)删除O(n)O(1)O(n)O(n)

ArrayList(实现动态数组),查询快(随意访问或顺序访问),增删慢。整体清空快,线程不同步(非线程安全)。数组长度是可变的百分之五十延长

LinkedList(实现链表),查询慢,增删快。

Vector(实现动态数组),都慢,被ArrayList替代。长度任意延长。线程安全(同步的类,函数都是synchronized)

Stack(实现堆栈)继承于Vector,先进后出。

所以,快速访问ArrayList,快速增删LinkedList,单线程都可以用,多线程只能用同步类Vector

“Java中ArrayList、LinkedList、Vector、Stack的对比”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

--结束END--

本文标题: Java中ArrayList、LinkedList、Vector、Stack的对比

本文链接: https://www.lsjlt.com/news/284662.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Java中ArrayList、LinkedList、Vector、Stack的对比
    本篇内容介绍了“Java中ArrayList、LinkedList、Vector、Stack的对比”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所...
    99+
    2023-06-16
  • java中ArrayList与LinkedList对比详情
     ArrayList,LinkedList都是Collection接口的通用实现方式,两者采用了不用的存储策略,用来适应不同场合的需要。实现方式  ArrayList的内部采用集合的方式存储数据唯一需要注意的是对于容量超过阈值的处理逻辑,数...
    99+
    2023-05-31
    java arraylist linkedlist
  • Java中ArrayList、Vector与Stack怎么用
    这篇文章主要为大家展示了“Java中ArrayList、Vector与Stack怎么用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Java中ArrayList、Vector与Stack怎么用”...
    99+
    2023-06-02
  • Java中LinkedList和ArrayList的效率分析
    在 Java 中,LinkedList 和 ArrayList 的性能是不同的,具体取决于你所需要的操作。 对于频繁的插入和删除操作,LinkedList 的性能通常更好,因为它使用...
    99+
    2023-02-10
    Java LinkedList和ArrayList效率 Java LinkedList ArrayList
  • 在Java中ArrayList和LinkedList的区别是什么
    Java中ArrayList和LinkedList的区别:ArrrayList数据结构是数组,支持随机访问,而 LinkedList数据结构是双向循环链表,不支持随机访问。ArrayList比LinkedList在随机访问的时候效率要高。A...
    99+
    2022-10-15
  • 在Java中ArrayList 和Vector的区别是什么
    Java中ArrayList和Vector的区别:ArrayList在性能方面要优于Vector。Vector使用了Synchronized来实现线程同步,是线程安全的,而ArrayList是非线程安全的。ArrayList通用性强,可以使...
    99+
    2022-10-24
  • Java中ArrayList和LinkedList之间的区别_动力节点Java学院整理
    一、ArrayListArrayList是一个可以处理变长数组的类型,这里不局限于“数”组,ArrayList是一个泛型类,可以存放任意类型的对象。顾名思义,ArrayList是一个数组列表,因此其内部是使用一个数组来存放对象的,因为Obj...
    99+
    2023-05-31
    java arraylist linkedlist
  • Java中对象的等价性对比
    本篇内容介绍了“Java中对象的等价性对比”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Java中不能简单的用==、!=等比较符对两个对象进...
    99+
    2023-06-17
  • java中-jar 与nohup的对比
    java中 -jar 与nohup的对比——作为Java程序员,经常会遇到这样一个问题,打个jar包,测试或者上线生产,于是乎面临的选择来了,java –jar or nohup? 下面我来扒一扒:一、  &n...
    99+
    2023-05-31
    java jar nohup
  • java 中sleep() 和 wait() 的对比
    java 中sleep() 和 wait() 的对比结合synchronized,会更好的理解sleep()和wait()这两个方法,当然也就知道了他们的区别了。这篇博客就一起学习这两个方法sleep()sleep() 方法是线程类(Thr...
    99+
    2023-05-31
    java sleep() wait()
  • 【java】对ArrayList中的元素进行排序的几种方式
    对ArrayList中的元素进行排序的几种方式 一、使用Collections工具类 1、对基本类型排序 通过Collections.sort()对基本类型排序默认是以升序排序 // 1.Collec...
    99+
    2023-09-08
    java Collections ArrayList Comparable接口 排序算法
  • java中Memcached和Redis的性能对比
    这篇文章将为大家详细讲解有关java中Memcached和Redis的性能对比,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。Java的特点有哪些Java的特点有哪些1.Java语言作为静态面...
    99+
    2023-06-14
  • java中继承的优缺点对比
    这篇文章将为大家详细讲解有关java中继承的优缺点对比,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。Java的特点有哪些Java的特点有哪些1.Java语言作为静态面向对象编程语言的代表,实...
    99+
    2023-06-14
  • java中StringBuffer的length()和capacity()方法对比
    StringBuffer的length()和capacity() StringBuffer类和String类差不多,都是字符串类,只是StringBuffer在对字符串进行修改时不会...
    99+
    2022-11-12
  • NumPy和JavaScript在Java中的性能对比?
    在编程领域,性能一直是一个非常重要的话题。对于数据密集型的应用程序而言,选择适当的工具和技术可以大大提高程序的性能。在这篇文章中,我们将重点比较NumPy和JavaScript在Java中的性能,并为您提供一些示例代码来帮助您更好地理解这...
    99+
    2023-10-18
    load javascript numpy
  • java中各种对象的比较方法
    目录前言1. 问题提出2. 元素的比较2.1 基本类型的比较2.2 对象的比较3. 对象的比较3.1 覆写基类的equal3.2 基于Comparble接口类的比较3.3 基于比较器...
    99+
    2023-05-18
    java对象比较方法 js 对象比较 java对象的比较
  • java中线程池的优缺点对比
    这篇文章将为大家详细讲解有关java中线程池的优缺点对比,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。Java的优点是什么1. 简单,只需理解基本的概念,就可以编写适合于各种情况的应用程序;...
    99+
    2023-06-14
  • Java中对象比较的示例分析
    这篇文章主要介绍了Java中对象比较的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。元素比较基本类型的比较在Java中,基本类型的对象可以直接比较大小public&n...
    99+
    2023-06-29
  • Java中常见的IO读写效率对比
    这篇文章主要介绍“Java中常见的IO读写效率对比”,在日常操作中,相信很多人在Java中常见的IO读写效率对比问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java中常见的IO读写效率对比”的疑惑有所帮助!...
    99+
    2023-06-17
  • java中对象的比较equal、Comparble、Comparator的区别
    目录关于对象值相等的比较三种比较风格覆写基类的equal关于对象值大于、等于、小于的比较–基于自然顺序(按照<小于号的形式)基于Comparble接口类的比较关于对象值大于、等...
    99+
    2022-11-12
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作