news 2026/4/20 16:04:01

java学习--LinkedList

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
java学习--LinkedList

一、LinkedList 是什么?

LinkedList 是 Java 集合框架中java.util包下的一个实现类,它实现了ListDeque等接口,底层基于双向链表实现(JDK 1.6 及之前是循环链表,之后改为双向链表)。

简单来说:

  • 链表的每个元素(节点)包含「前驱节点引用」、「数据」、「后继节点引用」
  • 没有固定大小的数组结构,元素在内存中不是连续存储的
  • 支持快速的头尾节点操作,也支持按索引访问(但效率低)

二、核心特性

  1. 增删效率高:在链表头部 / 尾部或指定节点附近增删元素时,只需修改节点引用,时间复杂度O(1)(按索引增删需先遍历找节点,复杂度O(n))。
  2. 查询效率低:按索引访问元素时,需要从链表头 / 尾开始遍历,时间复杂度O(n)(对比 ArrayList 的O(1))。
  3. 非线程安全:多线程环境下直接使用会有并发问题,需手动加锁或使用Collections.synchronizedList(new LinkedList<>())
  4. 支持双端操作:因为实现了Deque接口,可作为队列(Queue)、双端队列(Deque)、栈(Stack)使用。

三、常用操作示例

下面是 LinkedList 最常用的增删改查、队列 / 栈相关操作,代码可直接运行:

import java.util.LinkedList; import java.util.Queue; import java.util.Deque; public class LinkedListDemo { public static void main(String[] args) { // 1. 创建 LinkedList 对象 LinkedList<String> list = new LinkedList<>(); // 2. 新增元素 list.add("Java"); // 尾部添加 list.addFirst("Python"); // 头部添加 list.addLast("C++"); // 尾部添加(等同于 add) list.add(2, "Go"); // 指定索引添加(索引从0开始) System.out.println("初始链表:" + list); // [Python, Java, Go, C++] // 3. 查询元素 String first = list.getFirst(); // 获取头部元素:Python String last = list.getLast(); // 获取尾部元素:C++ String index2 = list.get(2); // 获取索引2的元素:Go System.out.println("索引2的元素:" + index2); // 4. 修改元素 list.set(1, "JavaScript"); // 修改索引1的元素 System.out.println("修改后链表:" + list); // [Python, JavaScript, Go, C++] // 5. 删除元素 list.removeFirst(); // 删除头部元素 list.removeLast(); // 删除尾部元素 list.remove(0); // 删除索引0的元素 System.out.println("删除后链表:" + list); // [] // 6. 作为队列(FIFO)使用 Queue<String> queue = new LinkedList<>(); queue.offer("A"); // 入队 queue.offer("B"); System.out.println("队列出队:" + queue.poll()); // A(出队并删除) System.out.println("队列首元素:" + queue.peek()); // B(仅查看) // 7. 作为栈(LIFO)使用(推荐用Deque而非Stack) Deque<String> stack = new LinkedList<>(); stack.push("X"); // 入栈 stack.push("Y"); System.out.println("栈出栈:" + stack.pop()); // Y(出栈并删除) System.out.println("栈顶元素:" + stack.peek()); // X(仅查看) } }

四、LinkedList vs ArrayList(核心区别)

特性LinkedListArrayList
底层结构双向链表动态数组
随机访问(get/set)慢(O (n))快(O (1))
增删操作(非头尾)慢(需遍历找节点,O (n))慢(需移动元素,O (n))
增删操作(头尾)快(O (1))慢(可能扩容,O (n))
内存占用高(每个节点存额外引用)低(连续存储,仅预留空间)
适用场景频繁增删头尾、队列 / 栈频繁查询、少量增删

总结

  1. LinkedList 底层是双向链表,核心优势是头尾增删快,劣势是随机访问慢
  2. 它不仅是 List,还能作为 Queue/Deque 使用,适合实现队列、栈等结构。
  3. 选择 LinkedList 还是 ArrayList,核心看操作场景:频繁查用 ArrayList,频繁头尾增删用 LinkedList。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 19:10:45

TVS管并联提升通流为何反而导致钳位不稳?

在车载与工业电源设计中&#xff0c;工程师常通过并联TVS管提升通流能力以应对高强度浪涌。然而工程实测数据显示&#xff0c;简单并联往往导致钳位电压剧烈波动、器件提前失效&#xff0c;甚至保护功能完全丧失。问题根源在于TVS的半导体特性与电路寄生参数的深度耦合。 一、击…

作者头像 李华
网站建设 2026/4/18 9:48:54

1986-2023年并购SDC数据库数据

并购SDC数据库通过收集、整理和分析并购交易数据&#xff0c;为学术研究、企业战略决策、投资分析等提供关键数据支持。 收录了自1986年以来全球范围内的并购、收购、资产剥离等各类交易信息。该数据库提供交易金额、支付方式、溢价水平、双方财务数据及行业分类等丰富指标。 …

作者头像 李华
网站建设 2026/4/16 19:31:09

python基于flask框架的在线编程学习系统设计与实现

目录基于Flask框架的在线编程学习系统设计与实现摘要开发技术路线相关技术介绍核心代码参考示例结论源码lw获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;基于Flask框架的在线编程学习系统设计与实现摘要 该系统采用Python语言与Flask轻量级框…

作者头像 李华
网站建设 2026/4/17 20:04:44

Day01-07.搭建项目环境-测试部署的微服务14:20

就是之前做过的那个单体项目&#xff0c;小程序&#xff0c;的微服务版本&#xff0c;加了一些主流技术栈&#xff0c;挺好的&#xff0c;可以上手实操看看。把学过的技术栈实操看看。每次工作有时间了&#xff0c;就学点新技术没时间也要创造时间&#xff0c;目前就是创造时间…

作者头像 李华
网站建设 2026/4/19 22:19:16

Agent搭建-超详细教程,存一下吧

AI Agent在于其能自动执行复杂任务&#xff0c;大幅提升自动化和智能决策的效率&#xff0c;让任务自动化&#xff0c;主要包括感知、记忆、规划与决策、行动/使用工具。 AI Agent的工作原理分为几个步骤。 ✔首先是感知&#xff0c;AI Agent通过传感器感知物理或虚拟环境中的变…

作者头像 李华