1.数据结构-链表

链表(Linked list)是一种常见的基础数据结构,是一种线性表,但是并不会按线性的顺序存储数据,而是在每一个节点里存到下一个节点的指针(Pointer)。

使用链表结构可以克服数组链表需要预先知道数据大小的缺点,链表结构可以充分利用计算机内存空间,实现灵活的内存动态管理。但是链表失去了数组随机读取的优点,同时链表由于增加了结点的指针域,空间开销比较大。

链表的类型:

  • 单向链表:单向链表包含两个域,一个信息域和一个指针域。这个链接指向列表中的下一个节点,而最后一个节点则指向一个空值。

  • 双向链表:双向链表每个节点有两个连接:一个指向前一个节点,(当此“连接”为第一个“连接”时,指向空值或者空列表);而另一个指向下一个节点,(当此“连接”为最后一个“连接”时,指向空值或者空列表)

  • 循环链表:在一个循环链表中, 首节点和末节点被连接在一起。

2.ArrayList结构特性

LinkedList 与 ArrayList 一样实现 List 接口,只是 ArrayList 是 List 接口的大小可变数组的实现,LinkedList 是 List 接口链表的实现。有以下特性:

  • 允许包含重复的元素
  • 允许包含null元素
  • 保存了元素添加的顺序
  • 不是线程安全的

3.构造方法

// 1.构造一个空列表
LinkedList() // 2.构造一个包含指定集合元素的列表
LinkedList(Collection<? extends E> c)

4.成员变量

// 1.链表中的元素数
transient int size // 2.指向第一个元素的指针
transient Node<E> first // 3.指向最后一个元素的指针
transient Node<E> last

5.常用的成员方法

// 1.添加一个元素到列表的尾部
boolean add(E e) // 2.添加一个元素到列表的指定位置
void add(int index, E element) // 3.将指定集合中的所有元素追加到此列表的末尾。
boolean addAll(Collection<? extends E> c) // 4.添加一个元素到列表的头部
void addFirst(E e) // 5.添加一个元素到列表的尾部
addLast(E e) // 6.检查列表中包含指定的元素
boolean contains(Object o) // 7.返回列表的第一个元素
E element() // 8.返回列表指定位置的元素
E get(int index) // 9.返回指定元素在列表中首次出现的索引
int indexOf(Object o) // 10.返回指定元素在列表中最后一次出现的索引
int lastIndexOf(Object o) // 11.添加一个元素到列表的尾部
boolean offer(E e) // 12.返回列表的第一个元素
E peek() // 13.删除并返回此列表的第一个元素
E poll() // 14.删除并返回此列表的第一个元素
E pop() // 15.添加一个元素到列表的头部
void push(E e) // 16.移除列表的第一个元素
E remove() // 17.设置指定位置的元素
E set(int index, E element) // 18.返回列表中的元素数
int size() // 19.返回一个数组,包含列表中所有元素
Object[] toArray()

6.Node节点

// LinkedList的静态内部类
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;
}
}

7.序列化原理

1.LinkedList 实现了Serializable接口,支持对象序列化

public class LinkedList<E>
extends AbstractSequentialList<E>
implements List<E>, Deque<E>, Cloneable, java.io.Serializable
{
......
}

2.序列化时调用 writeObject 方法,将 size 和 node 节点列表写入 ObjectOutputStream。

private void writeObject(java.io.ObjectOutputStream s)
throws java.io.IOException {
// Write out any hidden serialization magic
s.defaultWriteObject(); // 序列化 size
s.writeInt(size); // 从第一个元素开始,将链表中所有的元素序列化
for (Node<E> x = first; x != null; x = x.next)
s.writeObject(x.item);
}

3.反序列化时调用 readObject 方法,恢复 size 和 node 节点列表。

private void readObject(java.io.ObjectInputStream s)
throws java.io.IOException, ClassNotFoundException {
// Read in any hidden serialization magic
s.defaultReadObject(); // 恢复size
int size = s.readInt(); // 恢复链表
for (int i = 0; i < size; i++)
linkLast((E)s.readObject());
}

4.成员变量 size、first 和 last 使用 transient 关键字修饰,不会序列化到目的地中,从而节省时间和空间。

8.迭代器

1.由LinedList内部类ListItr实现ListIterator 接口,间接实现Iterator 接口。

public ListIterator<E> listIterator(int index) {
checkPositionIndex(index);
return new ListItr(index);
} private class ListItr implements ListIterator<E> {
// 最近返回的节点引用
private Node<E> lastReturned;
// 下一个节点的引用
private Node<E> next;
// 下一个节点的位置索引
private int nextIndex;
private int expectedModCount = modCount; ......
}

2.ListItr实现迭代器的成员方法

// 检查指针索引指向链表的边界
public boolean hasNext() {
return nextIndex < size;
} // 返回next 指向的节点,同时next偏移下一个节点
public E next() {
......
} // 移除最近返回的节点(lastReturned引用)
public void remove() {
......
}

9.总结

以上就是对LinkedList的理解,如果有不正确的地方,欢迎指正,最后,补一张脑图:

Java集合-LinkedList源码分析的更多相关文章

  1. Java入门系列之集合LinkedList源码分析(九)

    前言 上一节我们手写实现了单链表和双链表,本节我们来看看源码是如何实现的并且对比手动实现有哪些可优化的地方. LinkedList源码分析 通过上一节我们对双链表原理的讲解,同时我们对照如下图也可知道 ...

  2. Java集合---LinkedList源码解析

    一.源码解析1. LinkedList类定义2.LinkedList数据结构原理3.私有属性4.构造方法5.元素添加add()及原理6.删除数据remove()7.数据获取get()8.数据复制clo ...

  3. Java集合——LinkedList源码详解

    )LinkedList直接继承于AbstractSequentialList,同时实现了List接口,也实现了Deque接口. AbstractSequentialList为顺序访问的数据存储结构提供 ...

  4. Java集合框架源码分析(2)LinkedList

    链表(LinkedList) 数组(array)和数组列表(ArrayList)都有一个重大的缺陷: 从数组的中间位置删除一个元素要付出很大的代价,因为数组中在被删除元素之后的所有元素都要向数组的前端 ...

  5. java.util.LinkedList源码分析

    public class LinkedList<E> extends AbstractSequentialList<E> implements List<E>, D ...

  6. java中LinkedList源码分析

    ArrayList是动态数组,其实本质就是对数组的操作.那么LinkedList实现原理和ArrayList是完全不一样的.现在就来分析一下ArrayList和LinkeList的优劣吧LinkedL ...

  7. Java集合-ArrayList源码分析

    目录 1.结构特性 2.构造函数 3.成员变量 4.常用的成员方法 5.底层数组扩容原理 6.序列化原理 7.集合元素排序 8.迭代器的实现 9.总结 1.结构特性 Java ArrayList类使用 ...

  8. java集合系列之LinkedList源码分析

    java集合系列之LinkedList源码分析 LinkedList数据结构简介 LinkedList底层是通过双端双向链表实现的,其基本数据结构如下,每一个节点类为Node对象,每个Node节点包含 ...

  9. Java集合之LinkedList源码分析

    概述 LinkedLIst和ArrayLIst一样, 都实现了List接口, 但其内部的数据结构不同, LinkedList是基于链表实现的(从名字也能看出来), 随机访问效率要比ArrayList差 ...

随机推荐

  1. Blazor Webassembly多标签页实现非iframe的实现

    前面用iframe实现了多标签页,这次是不用iframe实现的多标签页.参考了一下Ant Design Blazor. 基本功能已经都实现了不论是标签滚动.激活.左移.右移.关闭其他,还是在内容页跳转 ...

  2. AT1381 エンド・オブ・ビギニング 题解

    Content 有 \(n\) 组询问,每组询问给定三个字符串 \(s_1,s_2,s_3\). 如果 \(s_1\) 是 BEGINNING,输出 \(s_3\) 的第一个字符. 如果 \(s_1\ ...

  3. libevent源码学习(6):事件处理基础——event_base的创建

    目录前言创建默认的event_baseevent_base的配置event_config结构体创建自定义event_base--event_base_new_with_config禁用(避免使用)某一 ...

  4. 在react项目中实现表格导出为Excel

    需求背景 数据表格有时需要增加导出Excel功能,大多数情况下都是后端出下载接口,前端去调用. 对于数据量少的数据,可以通过前端技术实现,减少后端工作. 实现方式 使用插件--xlsx 根据自己项目情 ...

  5. 论文解读SDCN《Structural Deep Clustering Network》

    前言 主体思想:深度聚类需要考虑数据内在信息以及结构信息. 考虑自身信息采用 基础的 Autoencoder ,考虑结构信息采用 GCN. 1.介绍 在现实中,将结构信息集成到深度聚类中通常需要解决以 ...

  6. Visual Studio Code常用快捷键

    说明 以下快捷键适用于windows环境下, Mac请将ctrl替换为command按键: 部分快捷键或不一样. 查看VSCode快捷键定义: settings -> keymaps. 目前使用 ...

  7. 【LeetCode】795. Number of Subarrays with Bounded Maximum 解题报告(Python & C++)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 动态规划 暴力搜索+剪枝 线性遍历 日期 题目地址: ...

  8. 【LeetCode】817. Linked List Components 解题报告(Python & C++)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 日期 题目地址:https://leetcode.c ...

  9. ELK集中化日志解决方案——看这一篇全搞定

    一.前言 在软件发开技术管理里有两个永恒经典的问题,适合我们初到一家软件企业或一家公司的科技团队,来判断自己该从哪里入手帮助整个团队提升科技水平和产能.问题一是"在我们团队里,只涉及一行代码 ...

  10. Linux开关机与登录注销

    开机和重启 shutdown -h now:立即关机计算机 shutdown -h 1:1分钟后关机 halt:立即关机 reboot:立即重启 sync:把内存的数据同步到磁盘 注: shutdow ...