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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 智慧小区解决方案ppt_智慧小区简介

    智慧小区解决方案ppt_智慧小区简介智慧小区项目遇到的问题汇总&解决参考跨域问题mybatisplus操作问题git操作问题跨域问题前端使用vue脚手架搭建项目,后端使用springboot+MySQL,首当其冲的问题是两者不能使用同一个端口启动,这就涉及到跨域操作。事实上,第一步,要在vue项目中的vue.config.js里添加//跨域parallel:require(‘os’).cpus().length>1,pwa:{},devServer:{port:8081,

    2022年10月17日
    1
  • 错误代码0xc0000005是什么错误_错误状态0xc0000006

    错误代码0xc0000005是什么错误_错误状态0xc0000006在使用电脑过程中经常会出现某些错误代码,如0xc0000005错误故障,造成电脑无法正常运行,这要怎么办呢?今天小编和大家分享电脑出现0xc0000005错误代码的解决方法。具体方法如下:1、首先按下“win+r”打开运行,输入regedit按下回车。2、随后依次定位到:HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Exp…

    2022年9月27日
    0
  • 微信公众平台接口调试工具

    微信公众平台接口调试工具微信公众平台为公众号开发者提供了网页版的接口调试工具,开发者可以直接在网页中调用对应的接口,比如获取access_token接口,创建菜单接口,发送消息接口等等。 先看一下界面,访问:http://mp.weixin.qq.com/debug/可以看到如下界面: 一、接口类型:因为微信公众号接口比较多,所以这里进行了分类,包括:基础支持、向用户发送消息、用户管理、自定义…

    2022年6月23日
    23
  • Chrome Devtool 断点[通俗易懂]

    Chrome Devtool 断点[通俗易懂]代码行断点代码中的代码行断点console.log(‘a’);console.log(‘b’);debugger;console.log(‘c’);DOM更改断点单击元素选项卡转到要设置断点的元素右键单击该元素将鼠标悬停在Break上,然后选择Subtree修改、属性修改或节点删除DOM更改断点的类型子树修改属性修改节点移除XHR/获取断点当在XHR请求URL包含特定字符串时中断展开XHRBreakpoints点击+输入字符串。当此字符串出现在X

    2022年9月26日
    0
  • PHP永久激活码2021(最新序列号破解)

    PHP永久激活码2021(最新序列号破解),https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月20日
    318
  • org.apache.jasper.JasperException: An exception occurred processing JSP page

    JPivothadanerror…org.apache.jasper.JasperException:AnexceptionoccurredprocessingJSPpage/testpage.jspatline4441:42:43:44: 45: 46: 47: Stacktrace:org.apache.jasper.JasperEx

    2022年4月9日
    202

发表回复

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

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