linkedList add方法源码分析

特点:它基于双向链表实现

  1. **双向链表结构:**每个节点都包含数据部分、前驱指针(指向前一个节点)和后继指针(指向后一个节点)在链表中间插入和删除元素时非常高效
  2. **查询性能较低:**因为它需要从链表的头部或尾部遍历到指定的索引位置
  3. **插入和删除性能高:**插入和删除元素时具有较高的性能。只需要修改元素的前后引用
  4. 线程不安全
  5. 允许存储空元素
  6. 内存开销较大

1.add(E e)

流程大概是这样的:除了开始和结尾节点的数据其他节点的数据都有一个前后指针,用来指向当前节点的上一个节点或当前节点的下一个节点,插入和删除元素的操作比较高效

java 复制代码
    /**
     * Links e as last element. 把当前元素作为最后一个元素
     */
    void linkLast(E e) {
        //1.获取这个集合的最后一个元素,初始添加为null
        final Node<E> l = last;
        //2.将传入的元素和最后一个元素放入node中
        final Node<E> newNode = new Node<>(l, e, null);
        //3.将传入的元素设置为最新元素
        last = newNode;
        //4.如果为null传入的元素就是第一个
        if (l == null)
            first = newNode;
        else
            //5.如果不为null传入的元素就是下一次传入的元素的前一个元素
            l.next = newNode;
        size++;
        modCount++;
    }

通过源码可知,数据的插入默认是从尾部添加的

相关推荐
pluviophile_s18 小时前
数据结构:第2讲:线性表
数据结构·笔记
Love_云宝儿21 小时前
WKT数据示例并与GeoJSON数据对比
数据结构·gis
风筝在晴天搁浅21 小时前
快手 CodeTop LeetCode 224.基本计算器
数据结构·算法·leetcode
牢姐与蒯1 天前
c++数据结构之c++11(一)
数据结构·c++
iiiiyu1 天前
IO流(二)
java·开发语言·数据结构·编程语言
啦啦啦啦啦zzzz1 天前
数据结构:平衡二叉树
数据结构·c++·二叉树
Ameilide1 天前
数据结构 树 二叉树
数据结构
WWW65261 天前
代码随想录 打卡第四十七天
数据结构·算法·leetcode
cpp_25011 天前
P10722 [GESP202406 六级] 二叉树
数据结构·c++·算法·题解·洛谷·树形结构·gesp六级
c238561 天前
map和set
数据结构·c++