ArrayList 和 LinkedList[通俗易懂]

ArrayList 和 LinkedList[通俗易懂]ArrayList 和 LinkedList

大家好,又见面了,我是你们的朋友全栈君。

ArrayList

ArrayList 是什么

看名字 Array(数组) 、List(列表) ,一个由数组实现的列表

ArrayList的特性

既然是通过数组这种数据结构实现的列表,那么 所以数组的特性 ArrayList 都有。

那么数组这种数据结构有什么特性呢。 参考数据结构之数组

可以简单归纳为三点

  • 在内存中拥有连续的存储空间,每个元素都对应一个下标
  • 添加(插入)、删除时,如果添加(插入)、删除点 后面存在数据,那么会导致后面数据的数组下标后移
  • 查找,修改时,由于有数组下标的存在,速度极快,时间复杂度是O(1)

除了以上数组共有的特点外,ArrayList还有以下特点

  • 空间不足时自动动态扩容
  • 线程不安全(不过因此也比线程安全的Vector性能好)
  • 实现了Serializable接口,支持序列化
  • 实现了Cloneable接口,能被克隆

适用场所

适用于 查找或修改较多,但添加(插入)、删除较少的场合

LinkedList

LinkedList 是什么

Linked(链接)、List(列表) ,一个由链表(具体来说是双向链表)实现的列表

LinkedList 的特性

因为是通过链表这种数据结构实现的列表,所以链表的特性 LinkedList 都有。

那么链表这种数据结构有什么特性呢。 参考数据结构之链表

可以简单归纳为三点

  • 在内存中是“零碎”的存储空间,每个链表节点的存储单元都存储着一个指向下一节点的引用
  • 添加(插入)、删除时,只需要修改添加(插入)、删除点先后的引用指向,效率极高
  • 查找、修改时,由于需要遍历链表,效率较慢

除了以上链表共有的特点外,LinkedList 还有以下特点

  • 是一个继承于AbstractSequentialList的双向链表
  • 实现了Cloneable接口,可以被克隆
  • java.io.Serializable接口,支持序列化
  • 线程不安全

适用场所

适用于 添加(插入)、删除较多,查找或修改较少的场合

转载于:https://juejin.im/post/5cd2a228e51d455c6049b7fc

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/106829.html原文链接:https://javaforall.net

(0)
上一篇 2022年4月22日 上午7:20
下一篇 2022年4月22日 上午7:40


相关推荐

  • (详细图解)VS2017安装教程

    (详细图解)VS2017安装教程VS2017版本同15版一样,细分为三个版本,分别是:社区版(Community):免费提供给单个开发人员,给予初学者及大部分程序员支持,可以无任何经济负担、合法地使用。 企业版:为正规企业量身定做,能够提供点对点的解决方案,充分满足企业的需求。企业版官方售价2999美元/年或者250美元/月。 专业版:适用于专业用户或者小团体。虽没有企业版全面的功能,但相比于免费的社区版,…

    2022年4月28日
    61
  • 一些有意思的 GitHub 项目

    一些有意思的 GitHub 项目GitFiti常用GitHub的同学应该知道GitHub的提交日历,每日提交的次数越多,颜色越深,于是有人写了此项目,可以自动根据配置提交不同次数的日志,这样即可画出指定的图案。看来程序员的脑洞也非常大啊!GitHub地址:https://github.com/gelstudios/gitfitiNoCode正如标题所示,“NoCode”,其作者是来…

    2022年7月16日
    17
  • mysql 窗口函数排序[通俗易懂]

    mysql 窗口函数排序[通俗易懂]窗口函数rank,dense_rank,row_numberselect*,rank()over(orderby成绩desc)asranking,dense_rank()over(orderby成绩desc)asdese_rank,row_number()over(orderby成绩desc)asrow_numfrom班级

    2026年4月14日
    3
  • PyCharm professionl2021激活码【在线破解激活】

    PyCharm professionl2021激活码【在线破解激活】,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月16日
    63
  • 【单调队列】数据结构之单调队列详解

    【单调队列】数据结构之单调队列详解单调队列1.初步认识单调队列是一个数据结构,并不是STL里面的内容。单调队列为何说单调,因为是队列中的元素始终保持着单增或者单减的特性。(注意始终保持这四个字)简单的sort排序就可以让一个序列有序了,为何又多此一举多出来个单调队列实现类似的功能呢?其实单调队列不只是做到了排序,还可以实现一个功能:在每次加入或者删除元素时都保持序列里的元素有序,即队首元素始终是最小值或者最大值,这个功能非常重要,单调队列我们就是使用的这个功能。举个例子:我们依次加入5个元素,分别为5,8,2,4,1那么我们假

    2022年6月25日
    21
  • 浅谈时间轮算法[通俗易懂]

    浅谈时间轮算法[通俗易懂]时间轮在计算机世界中,只有待解决的问题变得大规模后,算法的价值才能够最大化的体现。时间轮算法可以将插入和删除操作的时间复杂度都降为O(1),在大规模问题下还能够达到非常好的运行效果。如果我们要实现一个定时任务该如何实现呢?最简单的方式就是使用一个任务队列来完成定时任务。具体实现细节下面详细展开。

    2026年4月16日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号