ArrayList和LinkedList有什么区别?

news2024/9/29 5:29:13

ArrayList和LinkedList的区别

ArrayList 和 LinkedList 是 Java 中常用的两种集合类,它们都实现了 List 接口,但在内部实现和性能上有一些区别。

内部实现:

ArrayList 使用数组实现,它的元素在内存中是连续存储的,每个元素占用固定大小的内存空间。

LinkedList 使用链表实现,它的元素在内存中可以是分散存储的,每个元素可以有自己的大小。

随机访问:

ArrayList 支持高效的随机访问,因为它可以通过索引直接访问元素,时间复杂度为 O(1)

LinkedList 不支持高效的随机访问,如果要访问第 N 个元素,需要从头部或尾部开始遍历链表,时间复杂度为 O(N)。

插入和删除操作:

ArrayList 在列表的中间插入或删除元素时,需要将插入或删除位置后面的元素都向后或向前移动,时间复杂度为 O(N)。

LinkedList 在列表的中间插入或删除元素时,只需要改变相邻节点的指针,时间复杂度为 O(1)。

内存占用:

ArrayList 在添加或删除元素时可能会进行数组的扩容或收缩操作,这可能会导致一些额外的内存消耗和性能损失。

LinkedList 每个元素都需要额外的空间来存储指向下一个元素的指针,可能会占用更多的内存空间。

迭代器性能:

ArrayList 的迭代器性能通常比 LinkedList 的好,因为 ArrayList 的数据在内存中是连续存储的,迭代时不会产生额外的指针跳转操作

LinkedList 的迭代器性能可能较差,因为它的数据在内存中是分散存储的,迭代时可能会频繁地进行指针跳转

综上所述,当需要频繁进行随机访问操作时,选择 ArrayList 更合适;当需要频繁进行插入和删除操作时,选择 LinkedList 更合适。

 

ArrayList集合底层原理

ArrayList 是 Java 中的一个基本数据结构,它实现了 List 接口,采用动态数组的方式来存储元素。下面是关于 ArrayList 的详细介绍:

内部实现:

ArrayList 内部使用数组来存储元素。数组的大小可以动态增长,以容纳新的元素。当数组容量不足以容纳新元素时,ArrayList 会自动进行扩容操作,通常会创建一个新的数组,并将原数组中的元素复制到新数组中。

随机访问:

ArrayList 支持高效的随机访问。由于元素存储在数组中,并且数组的元素在内存中是连续存储的,因此可以通过索引来直接访问数组中的元素。因此,访问特定位置的元素的时间复杂度是 O(1)。

插入和删除操作:

尽管 ArrayList 对随机访问操作性能良好,但对于插入和删除操作,可能会涉及移动其他元素的情况。例如,在列表的中间插入一个元素,需要将插入位置后面的元素都向后移动一个位置。因此,插入和删除操作的时间复杂度通常是 O(N)。

迭代器:

ArrayList 提供了迭代器来遍历列表中的元素。迭代器支持快速的向前遍历,并且可以在常量时间内插入或删除当前位置的元素。

内存占用:

ArrayList 的内存占用相对较小。它只需要一个数组来存储元素,因此不会产生额外的指针或引用。但是,由于可能存在扩容操作,ArrayList 可能会分配比实际需要更多的内存空间。

适用场景:

ArrayList 适用于需要频繁进行随机访问操作的情况,例如需要根据索引获取元素或更新元素的值。它也适用于那些对列表进行遍历、迭代和转换的情况。

总的来说,ArrayList 提供了一种灵活且高效的数据结构,适用于各种需要列表功能的场景。然而,需要注意的是,对于大量插入和删除操作的情况,可能会有更适合的数据结构选择,比如 LinkedList。

扩容机制:

1.利用空参创建的集合,在底层创建一个默认长度为0的数组

2.添加第一个元素时,底层会创建一个新的长度为10的数组

3.存满时,会扩容一个1.5倍

4.如果一次添加多个元素,1.5倍还放不下,则新创建数组的长度以实际为准

096fff4ecb9646109e9ce645f31dd871.png

底层源码1

e6c097835a924a30a53bf1b3b838a5a7.png

底层源码2

77cb1b274adb462db6629543d2d6a422.png

 

LinkedList集合底层原理

30704dd836064d80af55dff5aa631965.png

LinkedList 是 Java 中的一个基本数据结构,它实现了 List 接口,采用链表的方式来存储元素。链表由一系列节点组成,每个节点包含一个数据元素以及指向下一个节点的引用。下面是关于 LinkedList 的一些详细介绍:

内部实现:

LinkedList 内部使用双向链表来存储元素每个节点都包含对前一个节点和后一个节点的引用。这种双向链表结构使得在链表中插入和删除元素的操作更加高效

9bde7ae9ae624b70a893661ea4f5f7b4.png

插入和删除操作:

由于链表的结构特点,LinkedList 对插入和删除操作具有良好的性能。在链表的任何位置插入或删除一个元素都可以在常量时间内完成,这是因为只需要调整相邻节点的引用。

随机访问:

与 ArrayList 不同,LinkedList 并不支持高效的随机访问。要访问链表中的特定位置的元素,必须从列表的开头或结尾开始遍历,直到找到目标位置。因此,访问特定位置的元素的时间复杂度是 O(N)。

迭代器:

LinkedList 提供了迭代器来遍历链表中的元素。这些迭代器支持快速的向前和向后移动,并且可以在常量时间内插入或删除当前位置的元素。

内存占用:

每个节点除了存储数据之外,还需要额外的空间来存储对前一个节点和后一个节点的引用。因此,相比于数组实现的 ArrayList,LinkedList 可能会占用更多的内存空间。

适用场景:

LinkedList 适用于频繁执行插入和删除操作,但不适用频繁进行随机访问的情况。例如,用作队列或栈的基础数据结构时,LinkedList 是一个很好的选择。

总的来说,LinkedList 在插入和删除操作上具有优势,但在随机访问上性能较差。因此,在选择数据结构时,应根据具体的使用场景和需求来进行选择。

ef8e5373aa3b49338fcb001e9257ab3d.png

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1550700.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【uniapp】uniapp实现免密登录

文章目录 一、概要二、整体架构流程三、技术名词解释四 、技术细节1.存取token有效期?2.使用setStorageSync而不使用setStorage?3.使用onLaunch而不使用全局路由? 一、概要 打开一个网页或小程序的时候,我们有时候会自动进入主页…

ExoPlayer架构详解与源码分析(12)——Cache

系列文章目录 ExoPlayer架构详解与源码分析(1)——前言 ExoPlayer架构详解与源码分析(2)——Player ExoPlayer架构详解与源码分析(3)——Timeline ExoPlayer架构详解与源码分析(4)—…

【XR806开发板试用】Ubuntu下烧写方法

烧写路径在工程目录下的device/xradio/xr806/xr_skylark/tools文件夹下,下载工具配置文件在 settings.ini 中 iBaud属性是波特率, strComDev属性是开发板连接电脑的usb口,通过 ls /dev/ttyUSB* 命令查询 之后在命令行输入 ./phoenixMC 开…

快速上手Pytrch爬虫之爬取某应图片壁纸

一、前置知识 1 爬虫简介 网络爬虫(又被称作网络蜘蛛、网络机器人,在某些社区中也经常被称为网页追逐者)可以按照指定的规则(网络爬虫的算法)自动浏览或抓取网络中的信息。 1.1 Web网页存在方式 表层网页指的是不需要提交表单&…

二叉树|450.删除二叉搜索树中的节点

力扣题目链接 class Solution { public:TreeNode* deleteNode(TreeNode* root, int key) {if (root nullptr) return root; // 第一种情况:没找到删除的节点,遍历到空节点直接返回了if (root->val key) {// 第二种情况:左右孩子都为空&…

bugku-web-Flask_FileUpload

查看页面源码 这里提示给他一个文件,它将返回一个python运行结果给我,并且提示只能上传jpg和png文件 传递一个图片 查看源码 传递一个非图片 将源码写入新建的txt文件中 print(hello world) 将文件后缀改为jpg 上传 上传成功 查看源码 得到运行结果 我…

python实战之基础篇(一)

1. 注释 # coding utf-8 # 该注释放到文件第一行, 这个注释告诉python解释器该文件的编码集是UTF-82. 导入语句有三种形式 import <模块名> from <模块名> import <代码元素> from <模块名> import <代码元素> as <代码元素别名>3. 获取…

Jmeter 从登录接口提取cookie 并 跨线程组调用cookie (超详细)

文章目录 一、开始前的准备二、 业务场景介绍三、从登录接口提取cookies四、跨线程组调用cookies 一、开始前的准备 1、安装Jmeter&#xff0c;参考文章&#xff1a;JMeter 3.1 和JMeterPlugin的下载安装 2、设置配置文件使Cookie管理器保存cookie信息。 修改apache-jmeter-x…

一题学会BFS和DFS,手撕不再怕

先复习一下什么是BFS和DFS&#xff0c;各位读者接着往下看就行 BFS算法 BFS类似于树的层次遍历过程,从根节点开始&#xff0c;沿着树的宽度遍历树的节点。如果所有节点均被访问&#xff0c;则算法中止。 舍去空间换时间。 算法思路队列&#xff08;先进先出&#xff09; 1…

应急 | BuleHero挖矿蠕虫最新变种分析

背 景 挖矿蠕虫病毒BuleHero擅长利用各类漏洞攻击、弱密码爆破攻击。病毒作者不断更新变种&#xff0c;是近期最活跃的挖矿蠕虫病毒之一。攻击者最新的BuleHero挖矿蠕虫实现入侵后&#xff0c;还会释放挖矿程序&#xff0c;使服务器的资源被消耗挖矿&#xff0c;极大影响正常业…

【EI会议征稿通知】电子、通信与智能科学国际会议(ECIS 2024)

电子、通信与智能科学国际会议&#xff08;ECIS 2024&#xff09; The International Conference on Electronics, Communications and Intelligent Science 电子、通信与智能科学国际会议&#xff08;ECIS 2024&#xff09;将于2024年05月24日-05月27日在中国长沙召开。ECIS…

Electron+Vue构建项目时出错:Error: Exit code: ENOENT. spawn /usr/bin/python ENOENT

问题&#xff1a;ElectronVue构建项目时出错&#xff1a;Error: Exit code: ENOENT. spawn /usr/bin/python ENOENT URL:https://github.com/nklayman/vue-cli-plugin-electron-builder/issues/1701 一&#xff0c;构建时node版本要低 同时构建命令如下&#xff1a; "el…

Linux——磁盘与文件系统管理

目录 磁盘分区的表示 硬盘分区 分区类型 确认系统中的磁盘设备——fdisk 规划硬盘中的分区——fdisk 文件系统 文件系统类型&#xff1a; 在分区中创建文件系统——mkfs&#xff0c;mkswap 挂载文件系统 mount命令 umount命令 查看分区挂载情况 设置启动载入&…

CCleaner2024最新版本win系统清理工具功能介绍及下载

CCleaner是一款在计算机领域广受欢迎的系统清理和优化工具。它以其强大的功能、简洁的操作界面和显著的效果&#xff0c;赢得了众多用户的青睐。下面&#xff0c;我将从功能、特点、使用方法以及优势等方面对CCleaner进行详细介绍。 CCleaner下载如下&#xff1a; https://wm.…

调用第三方接口:Http请求工具类

在对接第三方接口时&#xff0c;需要进行数据交互&#xff0c;于是写了一个 Java 的 Http 请求工具类&#xff0c;该工具类可以调用 Get 请求或者 POST 请求。 根据自己业务需求灵活修改&#xff0c;这里写了两个工具类&#xff0c;自己选一个就可以 直接上代码&#xff1a; …

Python模糊字符串匹配工具库之fuzzywuzzy使用详解

概要 Python的fuzzywuzzy库是一个强大的模糊字符串匹配工具,基于Levenshtein距离算法,可用于处理文本相似度匹配任务。本文将深入探讨fuzzywuzzy库的各种功能和用法,结合详细的描述和丰富的示例代码,带领大家全面了解这个工具的使用方法和实际应用场景。 安装 在开始使用…

【技巧】PyTorch限制GPU显存的可使用上限

转载请注明出处&#xff1a;小锋学长生活大爆炸[xfxuezhang.cn] 从 PyTorch 1.4 版本开始&#xff0c;引入了一个新的功能 torch.cuda.set_per_process_memory_fraction(fraction, device)&#xff0c;这个功能允许用户为特定的 GPU 设备设置进程可使用的显存上限比例。 测试代…

第115讲:Mycat核心配置文件各项参数的作用以及概念

文章目录 1.Mycat配置文件相关概念2.Schema配置文件3.Rule配置文件4.Server配置文件 1.Mycat配置文件相关概念 在Mycat中核心的配置文件有schema.xml和rule.xml以及server.xml三个&#xff0c;其中schema.xml是用来配置数据库、表、读写分离、分片节点、分片规则等信息&#x…

uniapp对接萤石云 实现监控播放、云台控制、截图、录像、历史映像等功能

萤石云开发平台地址&#xff1a;文档概述 萤石开放平台API文档 (ys7.com) 萤石云监控播放 首先引入萤石云js js地址&#xff1a;GitHub - Ezviz-OpenBiz/EZUIKit-JavaScript-npm: 轻应用npm版本&#xff0c;降低接入难度&#xff0c;适配自定义UI&#xff0c;适配主流框架 vi…

DC电源模块的设计与制造流程

BOSHIDA DC电源模块的设计与制造流程 DC电源模块是一种用于将交流电转换为直流电的设备。它广泛应用于各种电子设备中&#xff0c;如电子产品、工业仪器、电视等。下面是DC电源模块的设计与制造流程的简要描述&#xff1a; 1. 需求分析&#xff1a;在设计DC电源模块之前&#…