ArrayList和LinkedList有什么区别?

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.mzph.cn/news/775483.shtml

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

相关文章

lua 获取指定路径下的所有文件夹

一、io.popen 函数获取 io.popen 是 Lua 中的一个函数,它允许你执行一个外部命令并将命令的输出作为流处理。如果你想在 Lua 中通过 io.popen 执行 dir 命令(linux 命令是ls )来获取指定文件夹下的所有文件及其路径,你可以构造一个适用于 Windows 环境下…

【C语言】linux内核pci_iomap

一、pci_iomap /** pci_iomap 是一个用于映射 PCI 设备的 BAR(Base Address Register,基地址寄存器)的函数。* 此函数返回指向内存映射 IO 的指针,用于直接访问 PCI 设备的内存或 I/O 空间。* * 参数:* dev - 指向pci_dev结构的指…

【微服务篇】深入理解资源隔离,限流,熔断原理(Hystrix、Resilience4j和Sentinel)

限流、降级和资源隔离是分布式系统设计中常用的三种技术手段,它们主要目的是增强系统的稳定性和可用性,尤其在高并发和不稳定网络环境下显得尤为重要 1.资源隔离的实现方式 资源隔离通常有两种主要的实现方式:线程池隔离和信号量隔离。 线…

JDK8的下载安装与环境变量配置教程

前言 官网下载:Java Archive Downloads - Java SE 8u211 and later 现在应该没人用32位的系统了吧,直接下载Windows x64 Installer jdk-8u391-windows-x64.exe 一、安装JDK 1. 打开jdk-8u391-windows-x64.exe 2. 直接下一步 3. 这个地方不要动他&…

servlet开发详解

一、什么是servlet,干什么用的??? tomcat作为一个web服务器,也称作servlet容器。servlet只有放在web服务器中才能运行,不能独立运行。tomcat这个容器要做三件事:接收请求、处理请求和响应请求。…

从根本上优雅地解决 VSCode 中的 Python 模块导入问题

整体概述: 在我尝试运行 test_deal_file.py 时,我遇到了一个 ModuleNotFoundError 错误,Python告诉我找不到名为 controllers 的模块。这意味着我无法从 deal_file.py 中导入 read_excel 函数。 为了解决这个问题,我尝试了几种方法…

【ML】类神经网络训练不起来怎么办 5

【ML】类神经网络训练不起来怎么办 5 1. Saddle Point V.S. Local Minima(局部最小值 与 鞍点)2. Tips for training: Batch and Momentum(批次与 动量)2.1 Tips for training: Batch and Momentum2.2 参考文献:2.3 Gradient Descent2.4 Concluding Remarks(前面三讲)3.…

【QT】:基本框架

基本框架 一.创建程序二.初识函数1.main2.Widget.h3.Wight.cpp4.Wight.ui5.文件名.pro 三.生成的中间文件 本系列的Qt均使用Qt Creator进行程序编写。 一.创建程序 二.初识函数 1.main 2.Widget.h 3.Wight.cpp 4.Wight.ui 此时再点击编辑,就看到了ui文件的本体了。…

Django query

QuerySet API 参考 该文档描述了 QuerySet API 的细节。它是建立在 模型 和 数据库查询 指南的材料基础上的,因此,在阅读这篇文档之前,你可能需要阅读和理解这些文档。 在整个参考资料中,我们将使用在 数据库查询指南 中提出的 示…

数仓建设实践——58用户画像数仓建设

目录 一、数据仓库&用户画像简介 1.1 数据仓库简介 1.2 数据仓库的价值 1.3 用户画像简介 1.4 用户画像—标签体系 二、用户画像数仓建设过程 2.1 画像数仓—背景&现状 2.2 画像数仓—整体架构 2.3 画像数仓—研发流程 2.4 画像数仓—指标定义 2.5 画像数仓…

【有芯职说】数字IC前端工程师

数字IC前端设计 一、概述 数字IC前端设计,作为数字IC芯片设计流程的关键一环,是数字IC设计类岗位的重要组成部分。随着芯片规模的不断扩大与业务范围的增加,特别是在国产自主化潮流的推动下,该岗位的需求日益增长,经验丰富的工程师更是炙手可热。 数字IC前端设计主要包含…

RabbitMQ相关总结

Broker 异步调用中用Broker进行事件订阅和调用,完成解耦 没有强依赖,不用担心级联失败 流量削峰 MQ 的下载 1.可以使用命令拉取镜像 docker pull rabbitmq:3-management 2.也可以直接去官网下载tar包,然后上传到虚拟机上面 spring AMQP…

35岁程序员的经历和看法

35岁程序员的人生感悟:岁月见证的成长与转变 在程序员的世界里,35岁往往被视为一个重要的节点。对于许多人来说,这个年纪意味着成熟、稳定和经验的积累。作为一名35岁的程序员,我想分享一下自己的经历和看法。 回顾自己的职业生涯…

【数据库管理操作】Mysql 创建学生数据库及对数据表进行修改

MySQL 创建学生成绩数据库 1.创建数据库 create database studentscore;创建完成之后,如果需要使用该数据,使用use命令 use studentscore;创建表前查看当前数据库中包含的表 show tables; 2.创建bclass表 create table bclass( class_id char(8) …

程序员 35 真的会失业吗

35 岁被认为是程序员职业生涯的一个重要节点,引发了许多人对职业发展受限的担忧。一些人担心随着年龄的增长,难以跟上技术更新的步伐;而另一些人则坚信丰富的经验和深厚的技术积累是无法替代的财富。 然而,我认为 35 岁并非是程序…

Sublime 彻底解决中文乱码

1. 按ctrl,打开Console,输入如下代码: import urllib.request,os; pf Package Control.sublime-package; ipp sublime.installed_packages_path(); urllib.request.install_opener( urllib.request.build_opener( urllib.request.ProxyHand…

ubuntu之搭建samba文件服务器

1. 在服务器端安装samba程序 sudo apt-get install samba sudo apt-get install smbclient 2.配置samba服务 sudo gedit /etc/samba/smb.conf 在文件末尾追加入以下配置 [develop_share] valid users ancy path /home/ancy public yes writable y…

国内ip切换app,让切换ip变得简单

在数字化快速发展的今天,互联网已经成为我们生活中不可或缺的一部分。然而,随着网络应用的深入,用户对于网络环境的需求也日益多样化。其中,IP地址作为网络中的关键标识,其切换与管理显得尤为重要。为了满足用户对于IP…

每日一题 --- 链表相交[力扣][Go]

链表相交 题目:面试题 02.07. 链表相交 给你两个单链表的头节点 headA 和 headB ,请你找出并返回两个单链表相交的起始节点。如果两个链表没有交点,返回 null 。 图示两个链表在节点 c1 开始相交**:** 题目数据 保证 整个链式结…

【C语言】Infiniband驱动init_dev_assign函数

一、注释 一个内核模块的初始化函数,用于分配和初始化某些资源。以下是对代码块的逐行中文注释: // 定义一个初始化设备分配的函数 static void init_dev_assign(void) {int i 1;spin_lock_init(&dev_num_str_lock); // 初始化自旋锁if (mlx4_fil…