news 2025/12/24 0:57:33

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进行投诉反馈,一经查实,立即删除!
网站建设 2025/12/19 12:26:12

零基础教程:5分钟学会Excel转JSON

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 创建一个新手友好的Excel转JSON网页工具,界面只有上传按钮和下载按钮。自动识别Excel表头作为JSON键名,提供可视化预览功能。添加帮助气泡说明每个步骤&…

作者头像 李华
网站建设 2025/12/19 12:26:10

Chart.js终极指南:8大图表类型一键构建现代化数据可视化

Chart.js终极指南:8大图表类型一键构建现代化数据可视化 【免费下载链接】Chart.js 项目地址: https://gitcode.com/gh_mirrors/cha/Chart.js Chart.js是一款基于HTML5 Canvas的轻量级JavaScript图表库,自2013年发布以来已成为现代Web数据可视化…

作者头像 李华
网站建设 2025/12/19 12:25:50

电商网站自动化测试实战:Selenium IDE完整指南

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个电商网站自动化测试套件,针对典型用户旅程:1.访问电商首页 2.搜索特定商品 3.筛选商品 4.查看商品详情 5.加入购物车 6.结算流程。要求:…

作者头像 李华
网站建设 2025/12/19 12:25:37

Mustard UI 终极指南:轻量级前端框架的完整解决方案

Mustard UI 终极指南:轻量级前端框架的完整解决方案 【免费下载链接】mustard-ui A starter CSS framework that actually looks good. 项目地址: https://gitcode.com/gh_mirrors/mu/mustard-ui 在当今前端开发领域,轻量级可定制UI框架正成为开发…

作者头像 李华
网站建设 2025/12/24 4:13:11

GitTortoise实战:团队协作中的智能版本控制

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 创建一个团队协作场景下的GitTortoise应用演示,展示以下功能:1. 多人同时修改同一文件时的智能冲突检测与解决建议;2. 基于团队约定的提交信息规…

作者头像 李华
网站建设 2025/12/19 12:25:22

团队协作中如何避免Git工作树混乱?

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个团队协作工具,集成Git工作树状态检测功能。当团队成员尝试签出分支时,工具会自动检查工作树状态,提醒清理未提交的更改。支持多人协作场…

作者头像 李华