zoukankan      html  css  js  c++  java
  • 【Java集合】LinkedList详解中篇

    这是关于LinkedList的第二篇文章,我将会源码分析LinkedList的部分重要代码,关键地方我都有注释说明,希望大家能比较明白的看懂!

    分析源码按照顺序分析:

    • 变量
    • 构造方法
    • 方法

    一、变量

    注意:如果一个链表没有节点,那么first和last都为null

    二、构造方法

    三、方法

    1、linkFirst(E e)

    方法描述:将e这个节点加入链表头

    注意:

    • 头节点的pre指针指向的是null,并没有指向尾节点,所以并不是循环双向链表。
    • 如果当前链表只有一个节点,那么first和last指针均指向该节点

    2、linkLast(E e)

    方法描述:将e这个节点加入链表尾

    注意:

    • 尾节点的next指针指向的是null,并没有指向头节点,所以并不是循环双向链表。
    • 如果当前链表只有一个节点,那么first和last指针均指向该节点

    3、linkBefore(E e, Node succ)

    方法描述:将e这个节点加入到不为空的succ节点之前

    注意:

    • 该方法是往【succ节点】前加节点,所以需要判断该节点是否是头节点,原因是需要更改first这个指针指向的节点

    步骤:

    • 构造新的节点,它的prev指向【succ节点】的前一个节点,它的next指向【succ节点】
    • 【succ节点】的prev指向新的节点
    • 【succ节点】的前一个节点的next指向新节点

    4、unlinkFirst(Node f)

    方法描述:去掉不为空的头节点

    注意:

    • 如果【f节点】不是头结点,那么【f节点】之前【包括f节点】都将从链表中断开丢掉,只是size的减一存在问题

    步骤:

    • first指针指向【下一个节点】
    • 【f节点】的next不再指向【下一个节点】

    5、unlinkLast(Node l)

    方法描述:去掉不为空的尾节点

    注意:

    • 如果【l节点】不是尾结点,那么【尾节点】之后【包括l节点】都将从链表中断开丢掉,只是size的减一存在问题

    步骤:

    • last指针指向【上一个节点】
    • 【上一个节点】的next指向null

    6、unlink(Node x)

    方法描述:去掉不为空的【x节点】

    步骤:

    • 【上一个节点】的next指针指向【下一个节点】,【x节点】prev指向null
    • 【下一个节点】的prev指针指向【上一个节点】,【x节点】next指向null

    7、简单方法的概括

    8、add(E e)

    方法描述:向链表插入1个元素

    注意:

    • add方法默认是加元素加入【尾节点】

    9、remove(Object o)

    方法描述:移除链表中某个节点

    注意:

    • 这里判断了【被移除元素】是否为null的情况,为空则==即可,如果不为null,则需要equals来判断是否相等
    • == 和 equals的区别小伙伴们有兴趣可以查一查

    10、addAll

    方法描述:添加新的节点到链表中

    11、clear()

    方法描述:清除链表

     

  • 相关阅读:
    ros 录制
    shell 截取字符串
    Linux 关机
    shell获取字符串长度
    ubuntu14.04 设置开机自启动脚本
    获取本机ip的shell脚本
    shell 杀掉指定进程的服务
    html 绘制矩形轨迹,选中区域
    shell模拟ctrl c停止
    shell 字符串提取数字
  • 原文地址:https://www.cnblogs.com/yanphet/p/10385462.html
Copyright © 2011-2022 走看看