当前位置: 首页 > news >正文

LinkedList详解-Deque接口链表实现方案

简介

LinkedList实现了List和Deque接口。List是一个有序的集合,可以包含重复元素,它提供了在列表的头部、尾部或指定位置进行插入、删除和查找等操作的方法。Deque是双端队列,提供了在列表的头部和尾部进行插入和删除操作的方法。通过实现这两个接口,LinkedList可以灵活地用于各种不同的场景,并且可以方便地与其他使用这两个接口的代码进行交互。
在编程中用于存储和操作一系列有序的元素。它是由节点组成的链表,每个节点包含一个数据元素和一个指向下一个节点的指针。LinkedList的主要特点是它的元素可以动态地添加和删除,而且它支持在列表的头部、尾部或指定位置进行插入和删除操作。此外,LinkedList还支持一些其他操作,如查找元素、反转列表等。由于LinkedList是动态数据结构,它非常适合于需要在运行时进行动态调整的数据集合。


主要特点

  • 使用双向链表实现,不需要移动元素即可进行插入和删除操作,因此在插入和删除操作上具有较高的效率。
  • 支持随机访问,但效率较低,因为需要遍历整个链表来查找元素。
  • 由于每个元素都需要存储前驱和后继指针,所以相对于ArrayList等使用数组实现的集合类,LinkedList的存储空间会较大。
  • LinkedList直接实现了List接口,使其可以内部存储元素有序并且为每个元素提供索引值。
  • LinkedList直接实现了Deque接口,Deque接口继承了Queue,使其可以作为双向链表这种数据结构来使用、操作元素。
  • LinkedList直接实现了Cloneable接口,使其可以复制其中的全部元素。

构造函数

  • LinkedList():创建一个空的LinkedList。
  • LinkedList(Collection<? extends E> c):创建一个包含指定集合中所有元素的LinkedList。
  • LinkedList(int capacity):创建一个具有指定容量的LinkedList,以提高内存利用率。

需要注意的是,在创建LinkedList时,需要注意其容量和内存占用情况,以确保LinkedList能够有效地存储和处理数据。

常用方法

  • add(E e):在链表后添加一个元素。
  • addFirst(E e):在链表头部插入一个元素。
  • addLast(E e):在链表尾部添加一个元素。
  • push(E e):与addFirst方法一致。
  • offer(E e):在链表尾部插入一个元素。
  • remove():移除链表中第一个元素。
  • remove(E e):移除指定元素。
  • removeFirst(E e):删除头,获取元素并删除。
  • removeLast(E e):删除尾。
  • pollFirst():删除头。
  • pollLast():删除尾。
  • get(int index):按照下标获取元素。
  • getFirst():获取第一个元素。
  • getLast():获取最后一个元素。
  • peek():获取第一个元素,但是不移除。
  • peekFirst():获取第一个元素,但是不移除。
  • peekLast():获取最后一个元素,但是不移除。
  • poll():查询并移除第一个元素。

这些方法可以满足大部分操作需求,但具体使用哪种方法需要根据实际情况来决定。

使用场景

  • 需要频繁地删除、插入数据,且不需要或少用随机访问其中元素的场景 :在这种情况下,LinkedList更快速高效地添加删除元素的能力可以得到充分发挥。
  • 需要经常在头部、尾部或指定位置插入或删除元素的场景 :LinkedList支持在列表的头部、尾部或指定位置进行插入和删除操作,因此在这方面具有较高的效率。

例如,在实现一个简单的聊天室时,可以使用LinkedList来存储在线用户的列表,因为在这个场景中,需要频繁地添加和删除用户,而且不需要随机访问用户。

总之,LinkedList适用于需要频繁插入、删除、从头或尾部进行访问的场景。

代码示例

import java.util.LinkedList;public class LinkedListTest {public static void main(String[] args) {// 创建一个空的LinkedListLinkedList<String> list = new LinkedList<>();// 添加元素到LinkedListlist.add("Hello");list.add("World");list.add("!");// 在列表头部添加元素list.addFirst("Start");// 在列表尾部添加元素list.addLast("End");// 打印列表中的元素System.out.println("Elements in the list: " + list);// 移除第一个元素list.removeFirst();// 移除最后一个元素list.removeLast();// 获取列表中的第一个元素String firstElement = list.getFirst();System.out.println("First element: " + firstElement);// 获取列表中的最后一个元素String lastElement = list.getLast();System.out.println("Last element: " + lastElement);}
}

这个示例展示了如何创建一个空的LinkedList,添加元素到列表的头部和尾部,打印列表中的元素,移除第一个和最后一个元素,以及获取列表中的第一个和最后一个元素

注意事项

  • 插入和删除操作时,要确保指针的正确性,不要出现死循环或指针丢失的情况。
  • 在遍历LinkedList时,不要在遍历过程中对LinkedList进行结构性修改,这可能会导致ConcurrentModificationException异常。
  • 注意处理NullPointerException异常,确保LinkedList中不会出现空指针异常。
  • 在使用LinkedList时,要明确其适用场景,不要在需要随机访问的场景中使用LinkedList,因为LinkedList的访问效率相对较低。
  • 注意内存占用情况,因为LinkedList需要额外的空间来存储节点信息。
  • LinkedList是线程不安全的。在多线程环境下,如果多个线程同时对LinkedList进行修改操作(如添加、删除元素),可能会导致数据不一致的问题。因此,在多线程环境下使用LinkedList时,需要额外注意线程安全问题,可以考虑使用Collections.synchronizedList()方法将LinkedList包装成线程安全的列表,或者使用线程安全的ConcurrentLinkedDeque。

相关文章:

LinkedList详解-Deque接口链表实现方案

简介 LinkedList实现了List和Deque接口。List是一个有序的集合&#xff0c;可以包含重复元素&#xff0c;它提供了在列表的头部、尾部或指定位置进行插入、删除和查找等操作的方法。Deque是双端队列&#xff0c;提供了在列表的头部和尾部进行插入和删除操作的方法。通过实现这…...

【考研数据结构代码题1】二叉搜索树的插入与查找

题目&#xff1a;请用C语言写出二叉树的二叉链表结构&#xff0c;并编写一个函数在二叉搜索树中可以搜索给定的关键字 难度&#xff1a;★ 二叉树的二叉链表结构 #include<stdio.h> #include<stdlib.h> //二叉树的结点结构 typedef struct Node{int data;//存放结…...

世微 平均电流型降压恒流驱动器 电动摩托车LED灯小钢炮驱动IC AP5218

1&#xff0c;来源&#xff1a;深圳市世微半导体有限公司 2&#xff0c;产品描述 AP5218 是一款 PWM工作模式, 高效率、外 围简单、内置功率管&#xff0c;适用于5V&#xff5e;100V输入的高 精度降压 LED 恒流驱动芯片。输出最大功率可达 15W&#xff0c;最大电流 1.5A。AP5…...

docker 下安装mysql8.0

在docker中查询mysql镜像 PS C:\Users\admin> docker search mysql NAME DESCRIPTION STARS OFFICIAL AUTOMATED mysql MySQL is a widely used, open-source relation……...

Android MVI架构的深入解析与对比

什么是MVI&#xff1f; M&#xff1a;model&#xff0c;此处的model并不是传统的数据模块&#xff0c;它是指用来存储视图状态UI State的一个模块 。比如请求数据时的loading、请求失败的提示页面等UI层面的变化状态。 V&#xff1a;view&#xff0c;视图模块 I&#xff1a;…...

达梦数据库表空间管理常用SQL

达梦数据库表空间管理常用SQL 表空间容量分析表空间创建与扩容 查看数据库状态&#xff1a; select name,instance_name,status$,mode$ from v$instance; --mode$显示Primary为主库select name,status$,role$ from v$database; --status$&#xff1a;1 启动&#xff0c;2 启动…...

Flutter 组件集录 | InheritedNotifier 内置状态管理组件

theme: cyanosis 1. 前言 在上一篇 《Flutter 知识集锦 | 监听与通知 ChangeNotifier》 中&#xff0c;我们介绍了 ChangeNotifier 对象通知监听者的能力。并通过一个简单的模拟下载进度案例&#xff0c;介绍了它的使用方式&#xff1a; | 案例演示 | 监听-通知关系 | | --- | …...

NOIP2023模拟10联测31 涂鸦

题目大意 有一面由 n m n\times m nm个格子组成的墙&#xff0c;每个格子要么是黑色&#xff0c;要么是白色。你每次将会进行这样的操作&#xff1a;等概率随机选择一个位置 ( x , y ) (x,y) (x,y)和一个颜色 c c c&#xff08;黑色或白色&#xff09;&#xff0c;&#xff0…...

【Python基础知识一】基本语法、常用数据类型等

Python基础知识&#xff1a; 1 标识符&#xff08;Identifier&#xff09;2 关键字/保留字&#xff08;Keyword&#xff09;3 引号4 编码5 输入输出6 行与缩进7 多行语句8 注释9 数据类型9.1 数字(Number)类型9.2 变量&#xff08;variate&#xff09;9.3 字符串&#xff08;St…...

听听ChatGPT对IT行业的发展和就业前景的看法

&#x1f308;个人主页: Aileen_0v0&#x1f525;系列专栏:PYTHON学习系列专栏&#x1f4ab;"没有罗马,那就自己创造罗马~" 目录 (1)判断素数 写法1: 写法2: (2)计算1-100的偶数之和 写法1: 写法2: (3)计算1-100的奇数之和 (4)多层循环 IT行业哪个方向比较…...

〖程序员的自我修养 - 认知剖析篇⑤〗- 选择前端还是后端?

人之所以会觉得迷茫,本质上是欠缺对自己的一个控制力、识别庞杂信息、去伪存真的独立思考与认知能力。 说明:该文属于 程序员的自我修养 专栏,购买任意白宝书体系化专栏可加入易编程社区,早鸟价订阅模式除外。福利:加入社区的小伙伴们,除了可以获取博主所有付费专栏的阅读…...

Rust语言初步

文章目录 安装与测试变量条件语句和函数数组和元组循环 安装与测试 可以从官网直接下载。下载rustup-init并运行之后&#xff0c;会打开命令行&#xff0c;选1默认安装&#xff0c;然后不出意外就安装完了。 安装完成后按照惯例查看一下版本&#xff0c;如不报错就算成功。 …...

BIMILLC算法源码解析

论文链接&#xff1a;https://arxiv.org/abs/1607.02533 源码出处&#xff1a;https://github.com/Harry24k/adversarial-attacks-pytorch/tree/master 源码 import torch import torch.nn as nnfrom ..attack import Attackclass BIM(Attack):r"""BIM or iter…...

Android STR研究之五

前言&#xff1a; 在前四篇中初步介绍了开机流程&#xff0c;STR流程&#xff0c;唤醒流程&#xff0c;这里讲下STR的问题点 Android STR研究之一-CSDN博客 Android STR研究之二-CSDN博客 Android STR研究之三-CSDN博客 Android STR研究之四-CSDN博客 问题1&#xff1a;进入STR…...

python3+requests接口自动化测试实例详细操作

前段时间由于公司测试方向的转型&#xff0c;由原来的web页面功能测试转变成接口测试&#xff0c;之前大多都是手工进行&#xff0c;利用postman和jmeter进行的接口测试&#xff0c;后来&#xff0c;组内有人讲原先web自动化的测试框架移驾成接口的自动化框架&#xff0c;使用的…...

在Node.js中,什么是中间件(middleware)?它们的作用是什么?

聚沙成塔每天进步一点点 ⭐ 专栏简介 前端入门之旅&#xff1a;探索Web开发的奇妙世界 欢迎来到前端入门之旅&#xff01;感兴趣的可以订阅本专栏哦&#xff01;这个专栏是为那些对Web开发感兴趣、刚刚踏入前端领域的朋友们量身打造的。无论你是完全的新手还是有一些基础的开发…...

当函数参数为一级指针,二级指针

当函数参数为一级指针&#xff0c;二级指针 在讲述内容之前&#xff0c;先讲四点重要知识 1.当传入参数时&#xff0c;函数形参会立即申请形参的内存空间&#xff0c;函数执行完毕后&#xff0c;形参的内存空间立即释放掉。 1.指针是存放其他变量地址的变量。指针有自己的内…...

Hydra post登录框爆破

文章目录 无token时的Hydra post登录框爆破带Token时的Hydra post登录框爆破 无token时的Hydra post登录框爆破 登录一个无验证码和token的页面&#xff0c;同时抓包拦截 取出发送数据包&#xff1a;usernameadb&password133&submitLogin 将用户名和密码替换 userna…...

阿里云推出AI编程工具“通义灵码“;生成式 AI 入门教程 2

&#x1f989; AI新闻 &#x1f680; 阿里云推出AI编程工具"通义灵码"&#xff0c;支持多种语言及实时续写功能 摘要&#xff1a;阿里云推出了一款名为"通义灵码"的AI编程工具&#xff0c;支持多种主流编程语言&#xff0c;包括Java、Python、Go等。该工…...

使用Qt Installer Framework将自己的程序打包成安装包程序

使用Qt Installer Framework将自己的程序打包成安装包程序 制作安装包程序就是将自己的程序打包成一个可执行的exe&#xff0c;双击之后进行安装。 1. 在制作安装包程序之前需要安装qt官方提供的安装包制作工具Qt Installer Framework 去qt官方网址&#xff0c;下载对应的 Q…...

使用VSCode开发Django指南

使用VSCode开发Django指南 一、概述 Django 是一个高级 Python 框架&#xff0c;专为快速、安全和可扩展的 Web 开发而设计。Django 包含对 URL 路由、页面模板和数据处理的丰富支持。 本文将创建一个简单的 Django 应用&#xff0c;其中包含三个使用通用基本模板的页面。在此…...

springboot 百货中心供应链管理系统小程序

一、前言 随着我国经济迅速发展&#xff0c;人们对手机的需求越来越大&#xff0c;各种手机软件也都在被广泛应用&#xff0c;但是对于手机进行数据信息管理&#xff0c;对于手机的各种软件也是备受用户的喜爱&#xff0c;百货中心供应链管理系统被用户普遍使用&#xff0c;为方…...

树莓派超全系列教程文档--(61)树莓派摄像头高级使用方法

树莓派摄像头高级使用方法 配置通过调谐文件来调整相机行为 使用多个摄像头安装 libcam 和 rpicam-apps依赖关系开发包 文章来源&#xff1a; http://raspberry.dns8844.cn/documentation 原文网址 配置 大多数用例自动工作&#xff0c;无需更改相机配置。但是&#xff0c;一…...

MFC内存泄露

1、泄露代码示例 void X::SetApplicationBtn() {CMFCRibbonApplicationButton* pBtn GetApplicationButton();// 获取 Ribbon Bar 指针// 创建自定义按钮CCustomRibbonAppButton* pCustomButton new CCustomRibbonAppButton();pCustomButton->SetImage(IDB_BITMAP_Jdp26)…...

CMake基础:构建流程详解

目录 1.CMake构建过程的基本流程 2.CMake构建的具体步骤 2.1.创建构建目录 2.2.使用 CMake 生成构建文件 2.3.编译和构建 2.4.清理构建文件 2.5.重新配置和构建 3.跨平台构建示例 4.工具链与交叉编译 5.CMake构建后的项目结构解析 5.1.CMake构建后的目录结构 5.2.构…...

【Go】3、Go语言进阶与依赖管理

前言 本系列文章参考自稀土掘金上的 【字节内部课】公开课&#xff0c;做自我学习总结整理。 Go语言并发编程 Go语言原生支持并发编程&#xff0c;它的核心机制是 Goroutine 协程、Channel 通道&#xff0c;并基于CSP&#xff08;Communicating Sequential Processes&#xff0…...

ETLCloud可能遇到的问题有哪些?常见坑位解析

数据集成平台ETLCloud&#xff0c;主要用于支持数据的抽取&#xff08;Extract&#xff09;、转换&#xff08;Transform&#xff09;和加载&#xff08;Load&#xff09;过程。提供了一个简洁直观的界面&#xff0c;以便用户可以在不同的数据源之间轻松地进行数据迁移和转换。…...

Linux-07 ubuntu 的 chrome 启动不了

文章目录 问题原因解决步骤一、卸载旧版chrome二、重新安装chorme三、启动不了&#xff0c;报错如下四、启动不了&#xff0c;解决如下 总结 问题原因 在应用中可以看到chrome&#xff0c;但是打不开(说明&#xff1a;原来的ubuntu系统出问题了&#xff0c;这个是备用的硬盘&a…...

鸿蒙中用HarmonyOS SDK应用服务 HarmonyOS5开发一个生活电费的缴纳和查询小程序

一、项目初始化与配置 1. 创建项目 ohpm init harmony/utility-payment-app 2. 配置权限 // module.json5 {"requestPermissions": [{"name": "ohos.permission.INTERNET"},{"name": "ohos.permission.GET_NETWORK_INFO"…...

WordPress插件:AI多语言写作与智能配图、免费AI模型、SEO文章生成

厌倦手动写WordPress文章&#xff1f;AI自动生成&#xff0c;效率提升10倍&#xff01; 支持多语言、自动配图、定时发布&#xff0c;让内容创作更轻松&#xff01; AI内容生成 → 不想每天写文章&#xff1f;AI一键生成高质量内容&#xff01;多语言支持 → 跨境电商必备&am…...