当前位置:   article > 正文

《知识点023:Java中LinkedList.remove()删除数据》_java linkedlist删除数据

java linkedlist删除数据

 一、LinkedList类介绍

LinkedList类是双向列表,列表中的每个节点都包含了对前一个和后一个元素的引用.,它和ArrayList一样实现了List接口,但是她执行插入和删除操作时比ArrayList更加高效,因为她是基于链表的,但同时也决定了她在随机访问方面要比ArrayList弱一点。

1.1:结构原理

LinkedList底层的数据结构是基于双向循环链表的,且头结点中不存放数据,如下:

既然是双向链表,那么必定存在一种数据结构——我们可以称之为节点,节点实例保存业务数据,前一个节点的位置信息和后一个节点位置信息,如下图所示:


 

1.2:构造方法

  1. public LinkedList() {//生成空的链表
  2. header.next = header.previous = header;
  3. }
  4. public LinkedList(Collection<? extends E> c) {//复制构造函数
  5. this();
  6. addAll(c);
  7. }

第一个构造方法不接受参数,将header实例的previous和next全部指向header实例(注意,这个是一个双向循环链表,如果不是循环链表,空链表的情况应该是header节点的前一节点和后一节点均为null),这样整个链表其实就只有header一个节点,用于表示一个空的链表。执行完构造函数后,header实例自身形成一个闭环,如下图所示:

第二个构造方法接收一个Collection参数c,调用第一个构造方法构造一个空的链表,之后通过addAll将c中的元素全部添加到链表中。

二、LinkedList.remove()删除数据

2.1:方法

remove():获取并移除此列表的头(第一个元素)。
remove(int index):移除此列表中指定位置处的元素。
remove(Objec o):从此列表中移除首次出现的指定元素(如果存在)。
removeFirst():移除并返回此列表的第一个元素。
removeFirstOccurrence(Object o):从此列表中移除第一次出现的指定元素(从头部到尾部遍历列表时)。
removeLast():移除并返回此列表的最后一个元素。
removeLastOccurrence(Object o):从此列表中移除最后一次出现的指定元素(从头部到尾部遍历列表时)。

2.2:源码分析

(1)几个remove方法最终都是调用了一个私有方法:remove(Entry<E> e),只是其他简单逻辑上的区别。下面分析remove(Entry<E> e)方法。

  1. private E remove(Entry < E > e) {
  2. if (e == header) throw new NoSuchElementException();
  3. // 保留将被移除的节点e的内容
  4. E result = e.element;
  5. // 将前一节点的next引用赋值为e的下一节点
  6. e.previous.next = e.next;
  7. // 将e的下一节点的previous赋值为e的上一节点
  8. e.next.previous = e.previous;
  9. // 上面两条语句的执行已经导致了无法在链表中访问到e节点,而下面解除了e节点对前后节点的引用
  10. e.next = e.previous = null;
  11. // 将被移除的节点的内容设为null
  12. e.element = null;
  13. // 修改size大小
  14. size--;
  15. modCount++;
  16. // 返回移除节点e的内容
  17. return result;
  18. }

(2)由于删除了某一节点因此调整相应节点的前后指针信息,如下:
e.previous.next = e.next;//预删除节点的前一节点的后指针指向预删除节点的后一个节点。
e.next.previous = e.previous;//预删除节点的后一节点的前指针指向预删除节点的前一个节点。
 

(3)清空预删除节点:交给gc完成资源回收,删除操作结束。与ArrayList比较而言,LinkedList的删除动作不需要“移动”很多数据,从而效率更高。
e.next = e.previous = null;
e.element = null;

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/空白诗007/article/detail/935458
推荐阅读
相关标签
  

闽ICP备14008679号