迹忆客 专注技术分享

当前位置:主页 > 学无止境 > 编程语言 > Java >

Java 中 LinkedList 与 ArrayList 的区别?

作者:迹忆客 最近更新:2023/02/04 浏览次数:

LinkedListArrayList 都实现了 List 接口,但它们在内部的工作方式是不同之处。 ArrayListLinkedList 之间的主要区别在于 ArrayList 使用可调整大小的数组实现,而 LinkedList 使用双重 LinkedList 实现。 ArrayList 在 Java 程序员中比 LinkedList 更受欢迎,因为在很少情况下 LinkedList 是比 ArrayList 更合适的集合。 在本文中,我们将看到 LinkedList 和 ArrayList 之间的一些差异,并尝试找出 何时何地使用 LinkedList 而不是 ArrayList


Java 中的 LinkedList 与 ArrayList

LinkedListArrayList 之间的所有差异都源于 Array 和 LinkedList 数据结构之间的差异。 如果大家熟悉 Array 和 LinkedList 数据结构,那么很可能会得出它们之间的以下区别:

  1. 由于 Array 是基于索引的数据结构,因此使用索引从 Array 中搜索或获取元素非常快。 Array 为 get(index) 方法提供了 O(1) 性能,但是在 ArrayList 中移除是昂贵的,因为需要重新排列所有元素。 另一方面,LinkedList 不提供随机或基于索引的访问,我们需要遍历链表以检索 O(n) 阶的任何元素。
  2. 与 ArrayList 相比,LinkedList 中的插入操作简单且快速,因为如果数组变满,则不存在调整数组大小和将内容复制到新数组的风险,这使得在最坏的情况下添加到 O(n) 的 ArrayList 中,同时添加 是Java中 LinkedList 中的 O(1) 操作。 如果我们在数组末尾以外的任何地方插入内容,ArrayList 也需要更新其索引。
  3. 与 ArrayList 相比,删除在 LinkedList 中更像是插入。
  4. LinkedList 比 ArrayList 有更多的内存开销,因为在 ArrayList 中每个索引只保存一个实际对象(数据),但在 LinkedList 的情况下,每个节点都保存数据和下一个和上一个节点的地址。

何时在 Java 中使用 LinkedList 和 ArrayList

正如我们所说,LinkedList 不如 ArrayList 流行,但在某些情况下,LinkedList 是比 Java 中的 ArrayList 更好的选择。 如果出现以下情况,请在 Java 中使用 LinkedList:

  1. 我们的应用程序可以在没有随机访问的情况下生存。 因为如果你需要 LinkedList 中的第 n 个元素,你需要先遍历到第 n 个元素 O(n) 然后从该节点获取数据。
  2. 你的应用程序是更多的插入和删除驱动程序,你插入或删除的不仅仅是检索。 由于插入或移除不涉及调整大小,它比 ArrayList 快得多。

这就是 Java 中 ArrayListLinkedList 之间的区别。 在需要非同步的基于索引的访问的所有情况下,使用 Java 中的 ArrayList。 ArrayList 快速且易于使用,只需尝试通过构造具有适当初始大小的 ArrayList 来最大程度地减少数组大小调整。

转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处

本文地址:

相关文章

在 Java 中获取文件大小

发布时间:2023/05/01 浏览次数:139 分类:Java

Java 提供了不同的方法来获取文件的字节大小。 本教程演示了在 Java 中获取文件大小的不同方法。使用 Java IO 的文件类获取文件大小 Java IO 包的 File 类提供了以字节为单位获取文件大小的功能。

Java 中的文件分隔符

发布时间:2023/05/01 浏览次数:108 分类:Java

本篇文章介绍了 Java 中的文件分隔符。Java 中的文件分隔符 文件分隔符是用来分隔目录的字符; 例如,Unix 使用 /,Windows 使用 \ 作为文件分隔符。

Java 中的文件过滤器

发布时间:2023/05/01 浏览次数:193 分类:Java

本篇文章介绍如何在 Java 中使用 FileFilter。FileFilter 用于过滤具有特定扩展名的文件。 Java内置包IO和Apache Commons IO为FileFilter提供了类和接口来进行文件过滤操作。

Java 获取 ISO 8601 格式的当前时间戳

发布时间:2023/05/01 浏览次数:132 分类:Java

本篇文章介绍了 ISO 8601 日期格式、其重要性及其在 Java 中的使用。 它还列出了一些优点来强调为什么应该使用 ISO 格式来表示日期。

在 Java 中获取数组的子集

发布时间:2023/05/01 浏览次数:142 分类:Java

本篇文章介绍了几种在 Java 中获取数组子集的方法。使用 Arrays.copyOf() 方法获取数组的子集 使用 Arrays.copyOfRange() 方法获取数组的子集

用 Java 填充二维数组

发布时间:2023/05/01 浏览次数:110 分类:Java

二维数组是基于表结构的,即行和列,填充二维数组不能通过简单的添加到数组操作来完成。 本篇文章介绍如何在 Java 中填充二维数组。

Java 中的自然排序

发布时间:2023/05/01 浏览次数:132 分类:Java

Java 中最常用的顺序是自然顺序。 本文将展示如何使用 naturalOrder() 函数对数组进行排序。

计算 Java 数组中的重复元素

发布时间:2023/05/01 浏览次数:202 分类:Java

本篇文章介绍Java计算数组中重复元素的方法。计算 Java 数组中的重复元素。我们可以创建一个程序来计算数组中的重复元素。 该数组可以是未排序的,也可以是已排序的。

Java 中 List 和 Arraylist 的区别

发布时间:2023/05/01 浏览次数:90 分类:Java

表示为单个单元的一组单个对象称为集合。 在 Java 中,Collection 是一个具有多个已定义接口和类的框架,用于将一组对象表示为一个单元。 它允许我们操纵

扫一扫阅读全部技术教程

社交账号
  • https://www.github.com/onmpw
  • qq:1244347461

最新推荐

教程更新

热门标签

扫码一下
查看教程更方便