那些年,我们追过的Java List——ArrayList与LinkedList的爱恨情仇

简介: 【6月更文挑战第17天】ArrayList与LinkedList,Java List接口的双子星,各有千秋。ArrayList基于数组,随机访问快速,但插入删除慢;LinkedList用链表实现,插入删除高效,但索引访问慢。两者在爱恨情仇中教会我们权衡选择,成为编程旅程中难忘的记忆。```

在编程的漫漫征途中,我们曾无数次与Java List相遇、相知、相恋,又或许有过短暂的分离与重逢。其中,ArrayList与LinkedList,这两位List家族中的佼佼者,更是与我们结下了不解之缘。今天,就让我们一起回到那些年,回味一下与它们之间的爱恨情仇。

一、初识ArrayList

那些年,我们初入Java的殿堂,对List这个数据结构充满了好奇。而ArrayList,作为List家族中的佼佼者,以其独特的魅力吸引了我们的目光。它内部基于数组实现,可以动态扩展容量,提供了高效的随机访问能力。我们为它的简洁易用而倾倒,为它的高效性能而欢呼。

java
List arrayList = new ArrayList<>();
arrayList.add("Hello");
arrayList.add("World");
System.out.println(arrayList.get(0)); // 输出 "Hello"
然而,随着我们对ArrayList的深入了解,也发现了它的不足。在大量元素的插入和删除操作中,ArrayList需要频繁地移动元素,这导致了性能的下降。我们开始对ArrayList产生了一丝丝的不满。

二、邂逅LinkedList

正当我们对ArrayList感到失望时,LinkedList闯入了我们的视线。它基于双向链表实现,提供了高效的插入和删除操作,尤其适合在列表两端进行操作。我们为它的灵活性而赞叹,为它的高效性能而欣喜。

java
List linkedList = new LinkedList<>();
linkedList.add(1);
linkedList.addFirst(0); // 在头部插入元素
System.out.println(linkedList.getFirst()); // 输出 "0"
然而,好景不长。当我们试图通过索引访问LinkedList中的元素时,却发现其性能远不如ArrayList。因为LinkedList需要从头节点开始逐个遍历节点,直到找到目标元素。我们开始对LinkedList产生了疑虑。

三、爱恨交织

在与ArrayList和LinkedList的相处过程中,我们逐渐明白了它们的优缺点。ArrayList擅长随机访问,但在插入和删除操作上表现不佳;而LinkedList则擅长在列表两端进行插入和删除操作,但在随机访问上性能较差。我们开始在它们之间做出权衡和选择,根据实际需求选择合适的List实现。

那些年,我们与ArrayList和LinkedList共同度过了许多难忘的时光。它们陪伴我们度过了无数个日夜,见证了我们的成长和变化。无论未来我们走向何方,它们都将永远留在我们的记忆中。

相关文章
|
1月前
|
Java 索引 容器
Java ArrayList扩容的原理
Java 的 `ArrayList` 是基于数组实现的动态集合。初始时,`ArrayList` 底层创建一个空数组 `elementData`,并设置 `size` 为 0。当首次添加元素时,会调用 `grow` 方法将数组扩容至默认容量 10。之后每次添加元素时,如果当前数组已满,则会再次调用 `grow` 方法进行扩容。扩容规则为:首次扩容至 10,后续扩容至原数组长度的 1.5 倍或根据实际需求扩容。例如,当需要一次性添加 100 个元素时,会直接扩容至 110 而不是 15。
Java ArrayList扩容的原理
|
1月前
|
存储 Java 索引
Java中的数据结构:ArrayList和LinkedList的比较
【10月更文挑战第28天】在Java编程世界中,数据结构是构建复杂程序的基石。本文将深入探讨两种常用的数据结构:ArrayList和LinkedList,通过直观的比喻和实例分析,揭示它们各自的优势与局限,帮助你在面对不同的编程挑战时做出明智的选择。
|
2月前
|
安全 Java 程序员
深入Java集合框架:解密List的Fail-Fast与Fail-Safe机制
本文介绍了 Java 中 List 的遍历和删除操作,重点讨论了快速失败(fail-fast)和安全失败(fail-safe)机制。通过普通 for 循环、迭代器和 foreach 循环的对比,详细解释了各种方法的优缺点及适用场景,特别是在多线程环境下的表现。最后推荐了适合高并发场景的 fail-safe 容器,如 CopyOnWriteArrayList 和 ConcurrentHashMap。
69 5
|
2月前
|
Java 程序员 编译器
Java|如何正确地在遍历 List 时删除元素
从源码分析如何正确地在遍历 List 时删除元素。为什么有的写法会导致异常,而另一些不会。
42 3
|
2月前
|
Java 程序员
Java|List.subList 踩坑小记
不应该仅凭印象和猜测,就开始使用一个方法,至少花一分钟认真读完它的官方注释文档。
29 1
|
2月前
|
安全 Java 程序员
Java集合之战:ArrayList vs LinkedList,谁才是你的最佳选择?
本文介绍了 Java 中常用的两个集合类 ArrayList 和 LinkedList,分析了它们的底层实现、特点及适用场景。ArrayList 基于数组,适合频繁查询;LinkedList 基于链表,适合频繁增删。文章还讨论了如何实现线程安全,推荐使用 CopyOnWriteArrayList 来提升性能。希望帮助读者选择合适的数据结构,写出更高效的代码。
90 3
|
2月前
|
设计模式 安全 容器
数据结构第一篇【探究List和ArrayList之间的奥秘 】
数据结构第一篇【探究List和ArrayList之间的奥秘 】
29 5
|
2月前
|
算法 Java 测试技术
数据结构 —— Java自定义代码实现顺序表,包含测试用例以及ArrayList的使用以及相关算法题
文章详细介绍了如何用Java自定义实现一个顺序表类,包括插入、删除、获取数据元素、求数据个数等功能,并对顺序表进行了测试,最后还提及了Java中自带的顺序表实现类ArrayList。
35 0
|
存储 安全 Java
LinkedList源码解读—Java8版本(上)
LinkedList源码解读—Java8版本(上)
168 0
LinkedList源码解读—Java8版本(上)
|
Java
LinkedList源码解读—Java8版本(下)
LinkedList源码解读—Java8版本(下)
138 0