【JavaSE专栏49】Java集合类LinkedList解析,链表和顺序表有什么不同?

2023-07-20 08:51:36

作者主页Designer 小郑
作者简介:3年JAVA全栈开发经验,专注JAVA技术、系统定制、远程指导,致力于企业数字化转型,CSDN学院、蓝桥云课认证讲师。
主打方向:Vue、SpringBoot、微信小程序

本文讲解了 Java 中集合类 LinkedList 的语法、使用说明和应用场景,并给出了样例代码。

在这里插入图片描述


一、什么是LinkedList集合

LinkedList 集合是Java编程语言中的一种双向链表数据结构,它实现了 List 接口和 Deque 接口。

与 ArrayList 类似,LinkedList 也是一种动态数组,可以根据需要动态地增加或减少元素的大小。

然而,LinkedList 与 ArrayList 在内部实现和性能方面有所不同。

LinkedList 使用双向链表来存储元素,每个元素都包含一个指向前一个元素和后一个元素的引用,这种结构使得 LinkedList 在插入和删除元素时效率较高,因为它只需要调整节点的引用,而不需要移动其他元素。

但是,LinkedList 在随机访问元素时的性能相对较差,因为它需要遍历链表来获取指定索引处的元素。

LinkedList 提供了一系列方法来操作和管理元素。它实现了 List 接口和 Deque 接口的所有方法,包括添加、删除、获取和修改元素的方法。此外,LinkedList 还提供了一些特定于链表操作的方法,如 addFirst()addLast()removeFirst()removeLast() 等。

LinkedList的一些常见应用场景包括以下 5 5 5 类,请同学们认真学习。

  1. 需要频繁插入和删除元素的场景,因为 LinkedList 在插入和删除操作上效率较高。
  2. 实现队列和双向队列的场景,因为 LinkedList 实现了 Deque 接口。
  3. 实现堆栈的场景,可以使用 LinkedList 的 addFirst()removeFirst() 方法来模拟堆栈的入栈和出栈操作。
  4. 实现循环链表的场景,因为 LinkedList 的首尾节点相连,可以形成一个循环链表。
  5. 需要进行大量顺序遍历操作的场景,因为 LinkedList 的顺序遍历效率较高。

需要注意的是,与 ArrayList 一样,LinkedList 也不是线程安全的。如果在多个线程中同时访问和修改 LinkedList,可能会引发并发访问的问题,在多线程环境中使用 LinkedList 时,应该采取相应的线程安全措施,如使用同步机制或使用线程安全的替代方案。

在这里插入图片描述


二、LinkedList集合的使用

以下是 LinkedList 集合的一些常见使用方式的示例代码:

2.1 创建 LinkedList 集合、添加元素、遍历元素

LinkedList<String> linkedList = new LinkedList<>();
linkedList.add("apple");
linkedList.add("banana");
linkedList.add("orange");

for (String fruit : linkedList) {
    System.out.println(fruit);
}

2.2 在指定位置插入元素

LinkedList<String> linkedList = new LinkedList<>();
linkedList.add("apple");
linkedList.add("banana");
linkedList.add("orange");

linkedList.add(1, "grape");

System.out.println(linkedList); // 输出:[apple, grape, banana, orange]

2.3 获取指定位置的元素

LinkedList<String> linkedList = new LinkedList<>();
linkedList.add("apple");
linkedList.add("banana");
linkedList.add("orange");

String fruit = linkedList.get(1);
System.out.println(fruit); // 输出:banana

2.4 删除指定位置的元素

LinkedList<String> linkedList = new LinkedList<>();
linkedList.add("apple");
linkedList.add("banana");
linkedList.add("orange");

linkedList.remove(1);

System.out.println(linkedList); // 输出:[apple, orange]

2.5 在开头或末尾插入元素

LinkedList<String> linkedList = new LinkedList<>();
linkedList.add("apple");
linkedList.add("banana");
linkedList.add("orange");

linkedList.addFirst("grape");
linkedList.addLast("watermelon");

System.out.println(linkedList); // 输出:[grape, apple, banana, orange, watermelon]

在这里插入图片描述


三、LinkedList集合的应用场景

LinkedList 集合在以下场景中通常会得到应用,请同学们认真学习。

  1. 需要频繁地进行元素插入和删除操作的场景:由于 LinkedList 采用双向链表的数据结构,插入和删除元素的效率较高,因为只需要调整节点的引用即可,而不需要像数组一样移动其他元素。
  2. 实现队列和双向队列的场景:LinkedList 实现了 Deque 接口,因此可以用来实现队列和双向队列。例如,可以使用 LinkedList 的 addFirst()removeFirst() 方法来模拟队列的入队和出队操作。
  3. 实现堆栈的场景:LinkedList 也可以用来实现堆栈数据结构。通过使用 LinkedList 的 addFirst()removeFirst() 方法来模拟堆栈的入栈和出栈操作。
  4. 需要进行大量顺序遍历操作的场景:LinkedList 的顺序遍历效率较高,因为它是一个链表数据结构,可以按顺序依次遍历元素。
  5. 实现循环链表的场景:由于 LinkedList 的首尾节点相连,可以形成一个循环链表。这在某些场景下可能会有用,例如处理循环队列。

在这里插入图片描述


四、LinkedList面试题

一、Java 中的 LinkedList 是什么?

答:LinkedList 是 Java 集合框架中的一种双向链表实现的数据结构。它实现了 List 接口,可以存储各种类型的对象,并且支持插入、删除和访问操作。

二、LinkedList 和 ArrayList 的区别是什么?

答:LinkedList 和 ArrayList 都可以实现 List 接口,但它们的内部实现不同,主要区别如下。

  • LinkedList 是基于双向链表实现的,而 ArrayList 是基于动态数组实现的。
  • LinkedList 在插入和删除操作上具有更好的性能,因为只需要调整链表节点的指针,而 ArrayList 需要移动数组中的元素。
  • ArrayList 在随机访问操作上具有更好的性能,因为可以通过索引直接访问数组中的元素,而 LinkedList 需要从头节点或尾节点开始遍历链表。
  • LinkedList 需要更多的内存空间来存储链表节点的指针,而 ArrayList 需要更多的内存空间来存储数组的容量。

三、LinkedList 如何实现插入和删除操作?

答:LinkedList 通过操作节点的指针来实现插入和删除操作。

  • 在插入操作中,可以通过修改前后节点的指针来将新节点插入到链表中的任意位置。
  • 在删除操作中,可以通过修改前后节点的指针来删除指定节点。

四、LinkedList 适用于什么场景?

答:LinkedList 适用于以下情况:

  • 需要频繁地进行插入和删除操作。
  • 需要高效地使用迭代器进行遍历操作。
  • 不需要随机访问元素,或者只需要在链表的头部和尾部进行访问。

五、如何使用 LinkedList 的迭代器进行遍历?

答:可以通过调用 LinkedList 的 iterator() 方法来获取迭代器,并且使用 while 循环和 next() 方法来遍历链表中的元素。

LinkedList<String> linkedList = new LinkedList<>();
linkedList.add("A");
linkedList.add("B");
linkedList.add("C");

Iterator<String> iterator = linkedList.iterator();
while (iterator.hasNext()) {
    String element = iterator.next();
    System.out.println(element);
}

五、总结

本文讲解了 Java 中集合类 LinkedList 的语法、使用说明和应用场景,并给出了样例代码。在下一篇博客中,将讲解 Java 中 动态数组 Vector 类的知识。
在这里插入图片描述

更多推荐

解密堆排序与TopK问题

📙作者简介:清水加冰,目前大二在读,正在学习C/C++、Python、操作系统、数据库等。📘相关专栏:C语言初阶、C语言进阶、C语言刷题训练营、数据结构刷题训练营、有感兴趣的可以看一看。欢迎点赞👍收藏⭐留言📝如有错误还望各路大佬指正!✨每一次努力都是一种收获,每一次坚持都是一种成长✨目录前言1.堆排序1.1时间

Chrome扩展开发实战:网页图片抓取,打造专属自己的效率插件

🏆作者简介,黑夜开发者,CSDN领军人物,全栈领域优质创作者✌,CSDN博客专家,阿里云社区专家博主,2023年6月csdn上海赛道top4。🏆数年电商行业从业经验,历任核心研发工程师,项目技术负责人。🏆本文已收录于专栏:100个JavaScript的小应用。🎉欢迎👍点赞✍评论⭐收藏文章目录🚀一、背景🚀二

【C++多线程】Lambda表达式

定义Lambda表达式可以说是c++11引用的最重要的特性之一,虽然跟多线程关系不大,但是它在多线程的场景下使用很频繁,所以在多线程这个主题下介绍它更合适。Lambda来源于函数式编程的概念,也是现代编程语言的一个特点。C++11这次终于把Lambda加进来了,令人非常兴奋,因为Lambda表达式能够大大简化代码复杂度

《DevOps实践指南》- 读书笔记(七)

DevOps实践指南Part5第三步:持续学习与实验的技术实践19.将学习融入日常工作19.1建立公正和学习的文化19.2举行不指责的事后分析会议19.3尽可能广泛地公开事后分析会议结果19.4降低事故容忍度,寻找更弱的故障信号19.5重新定义失败,鼓励评估风险19.6在生产环境注入故障来恢复和学习19.7创建故障演练

利用容器技术优化DevOps流程

利用容器技术优化DevOps流程随着云计算的快速发展,容器技术也日益流行。容器技术可以打包和分发应用程序,并实现快速部署和扩展。在DevOps流程中,容器技术可以大大优化开发、测试、部署和运维各个环节。本文将介绍如何利用容器技术优化DevOps流程。首先,让我们了解一下背景知识。在传统的软件开发过程中,开发人员需要在本

DevOps&Apipost

DevOps旨在通过自动化流程和改善协作,实现软件开发、测试和交付的一体化,从而提高软件交付的质量和速度。为了提高工作效率,加快软件的交付流程,越来越多企业的选择DevOps工作流程。其中API管理的地位非常重要。随着API数量的大幅增长,也带来了新的API管理需求。如何在DevOps工作流中进行API全生命周期管理,

STM32WB55开发(1)----监测STM32WB连接状态

STM32WB55开发----1.监测STM32WB连接状态概述硬件准备视频教学样品申请完整代码下载选择芯片型号配置时钟源配置时钟树RTC时钟配置查看开启STM32_WPAN条件配置HSEM配置IPCC配置RTC启动RF开启蓝牙LED配置设置工程信息工程文件设置参考文档SVCCTL_App_Notification结果

STM32WB55开发(5)----调整射频功率

STM32WB55开发----5.调整射频功率概述硬件准备视频教学样品申请源码下载选择芯片型号配置时钟源配置时钟树RTC时钟配置查看开启STM32_WPAN条件配置HSEM配置IPCC配置RTC启动RF开启蓝牙开启串口调试配置蓝牙参数设置工程信息工程文件设置Keil工程配置代码配置射频功率ACI_HAL_SET_TX_

在Kubernetes上安装和配置Istio:逐步指南,展示如何在Kubernetes集群中安装和配置Istio服务网格

🌷🍁博主猫头虎带您GotoNewWorld.✨🍁🦄博客首页——猫头虎的博客🎐🐳《面试题大全专栏》文章图文并茂🦕生动形象🦖简单易学!欢迎大家来踩踩~🌺🌊《IDEA开发秘籍专栏》学会IDEA常用操作,工作效率翻倍~💐🌊《100天精通Golang(基础入门篇)》学会Golang语言,畅玩云原生,走遍大

基于 STM32自研多任务+SpringBoot+Vue 农业大棚智能调光系统

工作以后常常容易感到疲于奔命,即使在周末也没有得到高质量的休息。打工人/学生党如何过周末?你有哪些延长周末和下班时间的好方法吗?-方法就是多积累,多发博客,将感悟全写出来!!,接下来我给大家展示一个课程设计:源码和硬件端代码就不与展示了,在该博客的资源绑定中,大家如果有兴趣可以参考一下。前后端代码保存在我的资源中我的主

STM32 cubemx配置USART DMA传输

文章目录前言一、DMA概念二、STM32DMA数据手册分析3.DMA模式介绍4.cubemx配置总结前言本篇文章来讲解DMA的概念,并使用DMA来进行串口的数据收发。一、DMA概念DMA(DirectMemoryAccess,直接内存访问)是一种计算机系统的技术,允许外部设备(如硬盘驱动器、网络适配器或图形卡)直接与计

热文推荐