Java LinkedList的实现原理图文详解

首先,我们来了解一下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日

相关文章

  • 七段小代码解决Java程序常见的崩溃场景

    七段小代码所解决的Java程序常见的崩溃场景包括以下七种: 空指针异常(NullPointerException) 数组下标越界(ArrayIndexOutOfBoundsException) 类型转换异常(ClassCastException) 文件不存在异常(FileNotFoundException) 自定义业务异常(BusinessException…

    Java 2023年5月23日
    00
  • Springboot整合多数据源配置流程详细讲解

    下面我将为你详细讲解Springboot整合多数据源配置流程的完整攻略。 1. 引入多数据源依赖 在 pom.xml 文件中引入多数据源依赖。这里我们以 Druid 数据源为例,示例代码如下: <dependency> <groupId>com.alibaba</groupId> <artifactId>dru…

    Java 2023年5月20日
    00
  • Spring Boot2.0使用Spring Security的示例代码

    Spring Boot2.0使用Spring Security的示例代码 Spring Security是一个功能强大的安全框架,可以帮助我们实现身份验证、授权、攻击防护等功能。在Spring Boot2.0中,我们可以很方便地集成Spring Security,并实现基本的安全控制。本文将详细讲解Spring Boot2.0使用Spring Securit…

    Java 2023年5月15日
    00
  • Java运算符从见过到掌握上

    Java运算符是Java语言中非常重要的一个概念。它是程序员进行各种运算操作所必需的。从见过到掌握,需要我们经过以下步骤: 一、了解Java运算符的分类 Java运算符包括算术运算符、赋值运算符、比较运算符、逻辑运算符、位运算符和三目运算符。 算术运算符:+,-,*,/,%,++,–。 赋值运算符:=,+=,-=,*=,/=,%=等等。 比较运算符:==,…

    Java 2023年5月20日
    00
  • Spring Security权限控制的实现接口

    Spring Security是一个基于Spring框架的安全框架,用于实现用户认证(authentication)和授权(authorization)等安全功能。其中,权限控制是Spring Security的一个重要特性,可以通过编写实现接口来对系统中不同的资源进行授权控制。下面是完整的Spring Security权限控制实现接口攻略: 一、Sprin…

    Java 2023年6月3日
    00
  • 图解linux安装tomcat(附常用命令)

    图解Linux安装Tomcat(附常用命令) 在Linux安装Tomcat可能会遇到一些问题,本文将为你详细讲解Linux安装Tomcat的过程,同时也会介绍一些常用命令。 准备工作 在开始安装Tomcat之前,我们需要做一些准备工作。 1. 安装Java Tomcat运行在Java环境下,因此在安装Tomcat之前,需要先安装Java。下面是安装Java的…

    Java 2023年5月19日
    00
  • Javassist用法详解

    Javassist用法详解 Javassist是一个Java字节码操作库,它可以在运行时修改字节码从而对Java类进行动态编辑和代码生成。Javassist可以用于许多Java开发工具,例如实现AOP(面向切面编程)框架,实现ORM(对象关系映射)框架,实现动态代理等。 基本用法 在使用Javassist之前,我们需要在项目中引入Javassist的依赖: …

    Java 2023年5月26日
    00
  • 详解Java中的JDK、JRE、JVM

    详解Java中的JDK、JRE、JVM 在学习 Java 时,经常会听到三个概念:JDK、JRE、JVM。那么,JDK、JRE、JVM 的含义和作用各是什么呢?本文将详解解释。 JDK JDK(Java Development Kit)即 Java 开发工具包,是开发 Java 程序所必需的。JDK 包括两部分内容:一是 JRE(Java Runtime E…

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