news 2026/5/1 10:55:30

1.ArrayList和LinkedList的区别

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
1.ArrayList和LinkedList的区别
  • ArrayList总结

1.ArrayList的底层数据结构基于动态数组,连续内存存储,适合下标访问(随机访问)

2.扩容机制:因为数组长度固定,超出长度存数据时想要新建数组,然后把老数组中的数据拷贝到新数组

3.如果不是尾部插入数据还会涉及到元素的移动,使用尾插法并指定初始容量可以极大提升性能,甚至超过LinkedList(LinkedList插入元素需要创建大量的node对象)

ArrayList底层的数据结构是一个elementData数组

LinkedList总结

  1. 基于双向链表,可以存储在分散的内存中,适合做数据插入及删除操作(尾部插入和ArrayList差不多)
  2. LinkedList不存在扩容问题
  3. 遍历LinkedList必须使用iterator不能使用for循环,因为每次for循环内部通过get(i)取得某一元素时都需要对LinkedList重新进行遍历,性能消耗极大。

LinkedList底层数据结构是双向链表,当我向LinkedList中添加元素的时候,元素会被包装成一个node对象,node中有一个next(下一个节点)和prev(上一个节点)的两个指针,被称为双向链表

区别

1.ArrayList存储的时候要求数据都是挨在一起的连续的,LinkedList的数据可东一块西一块,只要用指针串起来就好了

2.ArrayList可以下标访问,LinkedList不可以下标访问,最推荐通过迭代器进行访问,如果使用for性能消耗极大

3.⾸先,他们的底层数据结构不同,ArrayList底层是基于数组实现的,LinkedList底层是基于链表实现的

4.由于底层数据结构不同,他们所适⽤的场景也不同,ArrayList更适合随机查找,LinkedList更适合删除和添加,查询、添加、删除的时间复杂度不同

5.另外ArrayList和LinkedList都实现了List接⼝,但是LinkedList还额外实现了Deque接⼝,所以LinkedList还可以当做队列来使⽤

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/1 4:43:25

3个关键步骤:用LabelImg打造高质量图像标注数据集

3个关键步骤:用LabelImg打造高质量图像标注数据集 【免费下载链接】labelImg 项目地址: https://gitcode.com/gh_mirrors/labe/labelImg 还在为AI模型训练效果不佳而苦恼?当模型精度停滞不前时,90%的问题根源往往在于标注数据的质量。…

作者头像 李华
网站建设 2026/5/1 4:42:01

FaceFusion在新闻播报机器人中的形象定制实践

FaceFusion在新闻播报机器人中的形象定制实践在媒体内容高速迭代的今天,观众对新闻播报形式的要求早已超越“准确”与“及时”,更追求真实感、亲和力与个性化体验。然而,传统虚拟主播系统依赖昂贵的3D建模和动作捕捉流程,难以快速…

作者头像 李华
网站建设 2026/5/1 4:42:44

如何快速配置NAS-Tools权限系统:面向新手的完整教程

你是否曾经担心家庭NAS中的私人照片被误删?是否希望为孩子设置专属的观影空间?NAS-Tools强大的权限系统正是为你量身打造的解决方案!本文将带你从零开始,轻松掌握权限配置的核心技巧,让你的媒体库管理既安全又高效。&a…

作者头像 李华
网站建设 2026/5/1 4:41:54

企业级应用:scrcpy在远程办公中的实战方案

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个企业级scrcpy解决方案,包含:1) 基于SSH的跨网络端口转发配置 2) 多设备管理界面 3) 操作日志审计功能 4) 权限管理系统。使用Flask构建Web管理后台&…

作者头像 李华
网站建设 2026/5/1 4:45:10

用AI助手GitTortoise,让代码提交更智能

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个基于AI的Git提交助手,能够自动分析代码变更,生成符合规范的提交信息,并推荐最佳分支策略。功能包括:1. 自动解析代码差异&am…

作者头像 李华
网站建设 2026/5/1 3:25:59

终极指南:5分钟掌握Unity状态机框架,轻松优化游戏状态管理

终极指南:5分钟掌握Unity状态机框架,轻松优化游戏状态管理 【免费下载链接】Unity3d-Finite-State-Machine An intuitive Unity3d finite state machine (FSM). Designed with an emphasis on usability, without sacrificing utility. 项目地址: http…

作者头像 李华