LinkedList源码分析

众所周知,LinkedList的底层是使用链表来存储实际的数据的,本文来探讨LinkedList的底层源码

LinkedList中的Node类

ini 复制代码
    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中的核心数据

ini 复制代码
transient int size = 0;  
  
transient Node<E> first;  

transient Node<E> last;

由上面的代码可知,LinkedList是一个具有头节点和尾节点的链表。

而且这些数据在Java默认的序列化中都不参与。

LinkedList初始化

空参构造

csharp 复制代码
public LinkedList() {  
}

LinkedList空参构造什么也没做。

通过集合构造

scss 复制代码
    public LinkedList(Collection<? extends E> c) {
        this();
        addAll(c);
    }

先调用空参构造,再调用addAll()添加数据。

增删改查

LinkedList不像ArrayList具有扩容机制,因此增删改查就是普通的链表增删改查。

相关推荐
翊谦14 小时前
Java Agent开发 Milvus 向量数据库安装
java·数据库·milvus
晓晓hh14 小时前
JavaSE学习——迭代器
java·开发语言·学习
查古穆14 小时前
栈-有效的括号
java·数据结构·算法
Java面试题总结14 小时前
Spring - Bean 生命周期
java·spring·rpc
硅基诗人14 小时前
每日一道面试题 10:synchronized 与 ReentrantLock 的核心区别及生产环境如何选型?
java
014-code14 小时前
String.intern() 到底干了什么
java·开发语言·面试
摇滚侠15 小时前
JAVA 项目教程《苍穹外卖-12》,微信小程序项目,前后端分离,从开发到部署
java·开发语言·vue.js·node.js
楚国的小隐士15 小时前
为什么说Rust是对自闭症谱系人士友好的编程语言?
java·rust·编程·对比·自闭症·自闭症谱系障碍·神经多样性
春花秋月夏海冬雪16 小时前
代码随想录刷题 - 贪心Part1
java·算法·贪心·代码随想录
野生技术架构师16 小时前
2026年牛客网最新Java面试题总结
java·开发语言