Java LinkedList的实现原理图文详解

yizhihongxing

首先,我们来了解一下Java LinkedList的基本特性。LinkedList是Java中实现链表数据结构的一种方式,它实现了List、Deque、Queue接口。LinkedList内部以链表的形式存储元素,每个节点都包含上一个节点的引用和下一个节点的引用。因此可以方便的在链表的任意位置进行添加、删除操作,但是随机访问某个元素的效率会比较低。

LinkedList类主要包含了以下几个成员变量:

transient int size = 0; // 链表大小,该变量用transient修饰,表示不会被进行序列化
transient Node<E> first; // 链表首节点
transient Node<E> last; // 链表尾节点

同时它还包括了一个内部类Node作为链表节点,该类包含了元素存储、上一个节点的引用和下一个节点的引用。

private static class Node<E> {
    E item;
    Node<E> next;
    Node<E> prev;

    Node(Node<E> prev, E element, Node<E> next) {
        this.item = element;
        this.next = next;
        this.prev = prev;
    }
}

接下来,我们可以看一下LinkedList的一些基本操作的实现过程。

1、添加元素

对于向链表尾部添加元素的操作,我们只需要将新元素添加到链表末尾节点的后面即可。

public boolean add(E e) {
    linkLast(e);
    return true;
}

void linkLast(E e) {
    final Node<E> l = last;
    final Node<E> newNode = new Node<>(l, e, null);
    last = newNode;
    if (l == null) {
        first = newNode;
    } else {
        l.next = newNode;
    }
    size++;
}

对于向链表中间位置添加元素的操作,我们需要将新元素插入到相应位置,并修改相应节点的前后节点的引用。

public void add(int index, E element) {
    checkPositionIndex(index);

    if (index == size) {
        linkLast(element);
    } else {
        linkBefore(element, node(index));
    }
}

void linkBefore(E e, Node<E> succ) {
    final Node<E> pred = succ.prev;
    final Node<E> newNode = new Node<>(pred, e, succ);
    succ.prev = newNode;
    if (pred == null) {
        first = newNode;
    } else {
        pred.next = newNode;
    }
    size++;
}

2、删除元素

对于删除尾部元素的操作,我们只需要将尾部节点的前一个节点作为新的尾部节点即可。

public E removeLast() {
    final Node<E> l = last;
    if (l == null)
        throw new NoSuchElementException();
    return unlinkLast(l);
}

private E unlinkLast(Node<E> l) {
    final E element = l.item;
    final Node<E> prev = l.prev;
    l.item = null;
    l.prev = null;
    last = prev;
    if (prev == null)
        first = null;
    else
        prev.next = null;
    size--;
    return element;
}

对于删除中间节点的操作,我们需要找到对应节点,修改上下节点的引用即可。

public E remove(int index) {
    checkElementIndex(index);
    return unlink(node(index));
}

E unlink(Node<E> x) {
    final E element = x.item;
    final Node<E> next = x.next;
    final Node<E> prev = x.prev;

    if (prev == null) {
        first = next;
    } else {
        prev.next = next;
        x.prev = null;
    }

    if (next == null) {
        last = prev;
    } else {
        next.prev = prev;
        x.next = null;
    }

    x.item = null;
    size--;
    return element;
}

通过以上基本操作可以看出,LinkedList主要是以双向链表的形式存储数据,因此可以方便的进行添加、删除等操作。但是由于需要遍历链表才能访问某个元素,因此不适用于随机访问与修改。

示例一:

LinkedList<Integer> list = new LinkedList<>();
list.add(1);
list.add(2);
list.add(3);
list.add(4);

以上示例添加了1、2、3、4四个元素到链表中。

示例二:

LinkedList<Integer> list = new LinkedList<>();
list.add(1);
list.add(2);
list.add(3);
list.add(4);
list.add(1, 5);

以上示例在第二个元素的位置插入了5这个元素。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Java LinkedList的实现原理图文详解 - Python技术站

(0)
上一篇 2023年5月26日
下一篇 2023年5月26日

相关文章

  • SpringBoot小程序推送信息的项目实践

    SpringBoot小程序推送信息的项目实践攻略 简介 本项目实践基于SpringBoot和小程序,实现了推送信息到小程序的功能。本文将详细讲解本项目的实现过程。 准备工作 开发工具:IDEA、微信开发者工具 开发环境:Java 8、Maven 3.6.3、SpringBoot 2.4.0、MySQL 8.0.21 创建SpringBoot项目 在IDEA中…

    Java 2023年5月20日
    00
  • JVM中四种GC算法案例详解

    详细讲解JVM中四种GC算法案例详解 首先需要介绍的是JVM的垃圾回收机制,JVM中的垃圾回收是基于GC算法实现的,GC算法按照实现机制可以分为如下四种: 标记-清除算法(Mark-Sweep Algorithm) 复制算法(Copying Algorithm) 标记-整理算法(Mark-Compact Algorithm) 分代回收算法(Generatio…

    Java 2023年5月19日
    00
  • 详解Java利用实现对称加密(DES、3DES、AES)

    详解Java利用实现对称加密(DES、3DES、AES) 介绍 对称加密是指加密与解密使用相同的密钥,具有加密速度快、适合加密大文件等优点。常用的对称加密算法有DES、3DES、AES等。 Java SE 提供了对称加密的实现,可以通过 javax.crypto 包中的 Cipher 类完成对称加密和解密操作。在此文中,我们将深入剖析如何使用 Cipher …

    Java 2023年5月19日
    00
  • Java实现优先队列式广度优先搜索算法的示例代码

    实现优先队列式广度优先搜索(Priority Queue-based BFS)算法需要遵循以下几个步骤: Step 1:初始化 首先,我们需要初始化一个待访问节点的优先队列priority queue、一个已访问节点的哈希表visited map、以及图的邻接表adjacent list。将源节点加入到priority queue中,并将visited ma…

    Java 2023年5月19日
    00
  • Dockerfile制作官方Tomcat镜像及镜像使用详解

    Dockerfile制作官方Tomcat镜像及镜像使用详解,需要分为两个部分来讲解:制作Tomcat镜像和使用Tomcat镜像。下面我将分别进行详细讲解。 制作Tomcat镜像 制作Tomcat镜像需要用到Dockerfile文件,具体步骤如下: 步骤一:选择合适的基础镜像 由于Tomcat是基于Java开发的应用服务器,因此可以选择Java镜像作为基础镜像…

    Java 2023年5月19日
    00
  • java中aop实现接口访问频率限制

    下面就是“Java中AOP实现接口访问频率限制”的完整攻略,包含以下几个步骤: 1. 添加依赖 首先,在项目中添加以下两个依赖: <dependency> <groupId>org.aspectj</groupId> <artifactId>aspectjweaver</artifactId> &l…

    Java 2023年5月20日
    00
  • SpringSecurity自定义登录成功处理

    Spring Security是一个基于Spring框架的安全框架,它提供了一系列的安全服务,包括身份验证、授权、攻击防护等。在Spring Security中,我们可以自定义登录成功处理来实现自定义的登录成功逻辑。在本文中,我们将详细讲解Spring Security自定义登录成功处理的完整攻略。 自定义登录成功处理 在Spring Security中,我…

    Java 2023年5月18日
    00
  • 微信小程序实现一键登录

    实现微信小程序的一键登录,可以使用微信开放平台提供的第三方授权登录功能。以下是具体的实现攻略: 1. 准备工作 首先要申请微信开放平台的帐号并完成认证 在开放平台中创建自己的小程序,并获取小程序的 AppID 和 AppSecret 2. 添加授权登录 将微信提供的授权登录组件添加到小程序中。 <!– index.wxml –> <bu…

    Java 2023年5月23日
    00
合作推广
合作推广
分享本页
返回顶部