【Java基础-44.2】Java中的LinkedList:特征与方法详解

news/2025/2/14 1:22:55/

在Java集合框架中,LinkedList是一个非常重要的数据结构,它实现了ListDeque接口,提供了双向链表的实现。与ArrayList不同,LinkedList在插入和删除操作上具有更高的效率,但在随机访问元素时性能较差。本文将深入探讨LinkedList的特征及其常用方法的应用。

1. LinkedList的特征

1.1 双向链表结构

LinkedList是基于双向链表实现的,每个节点(Node)都包含了对前一个节点和后一个节点的引用。这种结构使得LinkedList在插入和删除操作时非常高效,尤其是在列表的中间位置进行操作时。

1.2 动态大小

与数组不同,LinkedList的大小是动态的,可以根据需要自动扩展或缩小。这使得LinkedList在处理不确定数量的元素时非常灵活。

1.3 非同步

LinkedList不是线程安全的。如果多个线程同时访问一个LinkedList实例,并且至少有一个线程在结构上修改了列表,那么它必须在外部进行同步。

1.4 实现了Deque接口

LinkedList实现了Deque接口,因此它可以用作队列(FIFO)或双端队列(LIFO)。这使得LinkedList在需要实现栈或队列的场景中非常有用。

2. LinkedList的常用方法

2.1 添加元素

  • add(E e): 将元素添加到列表的末尾。
  • add(int index, E element): 在指定位置插入元素。
  • addFirst(E e): 将元素添加到列表的开头。
  • addLast(E e): 将元素添加到列表的末尾。
java">LinkedList<String> list = new LinkedList<>();
list.add("A");
list.addFirst("B");
list.addLast("C");
list.add(1, "D");
System.out.println(list); // 输出: [B, D, A, C]

2.2 删除元素

  • remove(): 移除并返回列表的第一个元素。
  • remove(int index): 移除指定位置的元素。
  • removeFirst(): 移除并返回列表的第一个元素。
  • removeLast(): 移除并返回列表的最后一个元素。
java">LinkedList<String> list = new LinkedList<>(Arrays.asList("A", "B", "C", "D"));
list.remove(); // 移除A
list.removeFirst(); // 移除B
list.removeLast(); // 移除D
System.out.println(list); // 输出: [C]

2.3 获取元素

  • get(int index): 返回指定位置的元素。
  • getFirst(): 返回列表的第一个元素。
  • getLast(): 返回列表的最后一个元素。
java">LinkedList<String> list = new LinkedList<>(Arrays.asList("A", "B", "C"));
System.out.println(list.get(1)); // 输出: B
System.out.println(list.getFirst()); // 输出: A
System.out.println(list.getLast()); // 输出: C

2.4 遍历元素

  • 使用迭代器: 可以使用IteratorListIterator遍历LinkedList
  • 使用增强for循环: 也可以使用增强for循环遍历。
java">LinkedList<String> list = new LinkedList<>(Arrays.asList("A", "B", "C"));// 使用迭代器
Iterator<String> iterator = list.iterator();
while (iterator.hasNext()) {System.out.println(iterator.next());
}// 使用增强for循环
for (String element : list) {System.out.println(element);
}

2.5 其他常用方法

  • size(): 返回列表中的元素数量。
  • clear(): 移除列表中的所有元素。
  • contains(Object o): 判断列表是否包含指定元素。
  • indexOf(Object o): 返回指定元素首次出现的索引,如果列表不包含该元素,则返回-1。
java">LinkedList<String> list = new LinkedList<>(Arrays.asList("A", "B", "C"));
System.out.println(list.size()); // 输出: 3
System.out.println(list.contains("B")); // 输出: true
System.out.println(list.indexOf("C")); // 输出: 2
list.clear();
System.out.println(list); // 输出: []

3. LinkedList的应用场景

3.1 频繁插入和删除操作

由于LinkedList在插入和删除操作上具有较高的效率,因此在需要频繁进行这些操作的场景中,LinkedList是一个很好的选择。例如,实现一个任务队列或事件处理系统。

3.2 实现栈和队列

LinkedList实现了Deque接口,因此可以很方便地用作栈或队列。例如,可以使用addFirstremoveFirst方法实现栈,使用addLastremoveFirst方法实现队列。

java">// 使用LinkedList实现栈
LinkedList<String> stack = new LinkedList<>();
stack.push("A");
stack.push("B");
System.out.println(stack.pop()); // 输出: B// 使用LinkedList实现队列
LinkedList<String> queue = new LinkedList<>();
queue.offer("A");
queue.offer("B");
System.out.println(queue.poll()); // 输出: A

3.3 需要双向遍历的场景

由于LinkedList是双向链表,因此可以很方便地进行双向遍历。例如,可以使用ListIterator从后向前遍历列表。

java">LinkedList<String> list = new LinkedList<>(Arrays.asList("A", "B", "C"));
ListIterator<String> iterator = list.listIterator(list.size());
while (iterator.hasPrevious()) {System.out.println(iterator.previous());
}

4. LinkedList与ArrayList的比较

特性LinkedListArrayList
数据结构双向链表动态数组
随机访问性能较差较好
插入和删除性能较好(尤其在中间位置)较差(尤其在中间位置)
内存占用较高(每个节点需要额外的指针空间)较低
适用场景频繁插入和删除操作频繁随机访问操作

5. 总结

LinkedList是Java集合框架中一个非常灵活的数据结构,特别适用于需要频繁插入和删除操作的场景。它提供了丰富的方法来操作列表,并且可以方便地用作栈或队列。然而,在需要频繁随机访问元素的场景中,ArrayList可能是更好的选择。

通过本文的介绍,相信你已经对LinkedList的特征及其常用方法有了更深入的了解。在实际开发中,根据具体需求选择合适的集合类,可以大大提高程序的效率和可维护性。


http://www.ppmy.cn/news/1571841.html

相关文章

港中文腾讯提出可穿戴3D资产生成方法BAG,可自动生成服装和配饰等3D资产如,并适应特定的人体模型。

今天给大家介绍一种名为BAG&#xff08;Body-Aligned 3D Wearable Asset Generation&#xff09;的新方法&#xff0c;可以自动生成可穿戴的3D资产&#xff0c;如服装和配饰&#xff0c;以适应特定的人体模型。BAG方法通过构建一个多视图图像扩散模型&#xff0c;生成与人体对齐…

Spring Boot + MyBatis Field ‘xxx‘ doesn‘t have a default value 问题排查与解决

目录 1. 问题所示2. 原理分析3. 解决方法1. 问题所示 执行代码的时候,出现某个字段无法添加 ### Error updating database. Cause: java.sql.SQLException: Field e_f_id doesnt have a default value ### The error may exist in cn

Gemini 2.0模型更新:谷歌最新AI大模型全面开启智能时代

引言 2025年2月5日&#xff0c;谷歌人工智能实验室&#xff08;Google DeepMind&#xff09;发布了最新的Gemini 2.0模型系列更新&#xff0c;包括2.0 Flash、Flash-Lite和Pro实验版本。这些AI大模型的发布标志着人工智能技术在性能、效率和多模态能力上的进一步突破&#xff…

Docker Desktop Windows 安装

一、先下载Docker desktop WIndows 下载地址 二、安装 安装超简单 一路 下一步 三、安装之后&#xff0c;桌面会出现一个 小蓝鲸图标&#xff0c;打开它 》更新至最新版本&#xff0c;不然小蓝鲸打开&#xff0c;一会就退出了。 》wsl --update &#xff08;这个有时比较慢…

【自学笔记】AIGC基础知识点总览-持续更新

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 AIGC基础知识点总览一、AIGC概述二、AIGC的核心要素三、AIGC的关键技术1. 深度学习算法2. 自然语言处理&#xff08;NLP&#xff09;3. 计算机视觉&#xff08;CV&a…

C# 上位机--枚举

一、引言 在 C# 上位机开发过程中&#xff0c;枚举&#xff08;Enum&#xff09;是一种非常实用的数据类型&#xff0c;它可以将一组相关的常量组织在一起&#xff0c;使代码更加清晰、易读和易于维护。 二、枚举的基本概念 枚举&#xff08;Enum&#xff09;是一种值类型&a…

【虚幻引擎UE】AOI算法介绍与实现案例

【虚幻引擎UE】AOI算法介绍与实现 一、AOI算法介绍AOI算法的典型应用场景二、AOI相关算法1. 边界框法(Bounding Box Method)2. 动态AOI算法3. 布尔运算(Boolean Operations)4. 四叉树(Quadtree)5. R树(R-Tree)6. 圆形AOI算法7. 网格分割(Grid Partitioning)8. 多边形…

命令行参数、环境变量、进程地址空间及 2.6 内核调度队列解读

目录 一、命令行参数与环境变量探秘 1.1 命令行参数的本质作用 1.2 环境变量实战指南 &#x1f335;关键环境变量解析 &#x1f335;测试PATH&#xff1a; &#x1f335;测试HOME&#xff1a; &#x1f335;环境变量的组织方式&#xff1a; &#x1f335;环境变量操作命…