Java集合3-LinkedList

介绍

LinkedList是一种双向链表数据结构,实现了 List 接口。具有

LinkedList底层由一系列节点组成,每个节点包含了对前一个节点和后一个节点的引用。这种结构允许在链表中高效地插入和删除元素,因为不需要像数组那样移动元素。每个节点通常会包含一个数据元素。

新增

java 复制代码
  public boolean add(E e) {
        linkLast(e);
        return true;
    }
     /**
     * Links e as last element.
     */
    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++;
        modCount++;
    }

可见每次插入都是移动节点,和 ArrayList 的拷贝数组来说效率要高上不少

结构

LinkedList的节点由Node类实现,它通常是一个私有内部类。Node类通常包含三个字段:item用于存储数据元素,prev用于指向前一个节点,next用于指向后一个节点。

LinkedList还包含指向链表头部和尾部的引用。这些引用使得在链表的开头和末尾进行操作更加高效。

LinkedList不支持通过索引直接访问元素。要访问特定位置的元素,必须从头节点或尾节点开始遍历列表,直到找到所需位置的元素。因此,索引访问的时间复杂度是O(n),其中n是列表的长度。

查询方法

java 复制代码
    public E get(int index) {
        checkElementIndex(index);
        return node(index).item;
    }
    
    Node<E> node(int index) {
        // assert isElementIndex(index);

        if (index < (size >> 1)) {
            Node<E> x = first;
            for (int i = 0; i < index; i++)
                x = x.next;
            return x;
        } else {
            Node<E> x = last;
            for (int i = size - 1; i > index; i--)
                x = x.prev;
            return x;
        }
    }

上述代码,利用了双向链表的特性,如果index离链表头比较近,就从节点头部遍历。否则就从节点尾部开始遍历。使用空间(双向链表)来换取时间。

迭代器LinkedList实现了java.util.List接口,因此支持使用迭代器进行遍历操作。迭代器在LinkedList中的实现是双向的,因此可以在任一方向上进行迭代,使得在列表中移动元素非常高效。

线程不安全LinkedList的实现不是线程安全的,如果需要在多线程环境下使用,需要手动保证同步。

相关推荐
m0_635647489 分钟前
Qt打包含有第三方库的软件为应用程序——CQtDeployer
开发语言·数据库·qt
simple-L616 分钟前
Vue3 前端开发技术文章大纲
开发语言
南宫萧幕18 分钟前
Python与Simulink联合仿真:基于DQN的HEV能量管理策略建模与全链路排雷实战
开发语言·人工智能·python·算法·机器学习·matlab·控制
千寻girling24 分钟前
滑动窗口刷了快一个月(26天)了 , 还没有刷完. | 含(操作系统学什么的Java 后端)
java·开发语言·javascript·c++·人工智能·后端·python
小手cool24 分钟前
Java字符串按空行分割,包括末尾的空行
java
曾凡玉@35 分钟前
Python 并发编程系统笔记
开发语言·笔记·python
代码中介商36 分钟前
C语言核心知识完全回顾:从数据类型到动态内存管理
c语言·开发语言
故事还在继续吗40 分钟前
C++多线程与多进程编程
开发语言·c++
呱牛do it43 分钟前
企业级门户网站设计与实现:基于SpringBoot + Vue3的全栈解决方案(Day 9)
java
幽络源小助理1 小时前
影视脚本分镜在线协作系统源码 PHP剧本创作平台
开发语言·php