java需要关注的知识点---LinkedList

本文详细介绍了Java中的LinkedList数据结构,包括其双向链表实现原理、构造函数、add和remove方法的具体实现过程,并通过图示直观展示了元素插入和删除的操作。
LinkedList是采用双向链表来存储数据:

LinkedList允许插入null的值
双向链表的结构图:



LinkedList的构造函数:
Java代码   收藏代码
  1. public LinkedList() {  
  2.       header.next = header.previous = header;  
  3.   }  

LinkedList在构造函数中初始化双向链表的表头header,指定header的上一个和下一个都是自己。
LinkedList的add方法:
Java代码   收藏代码
  1. public boolean add(E e) {  
  2. addBefore(e, header);  
  3.        return true;  
  4.    }  

在进行插入元素的时候,传入插入元素和header.
LinkedList的addBefore方法:
Java代码   收藏代码
  1. private Entry<E> addBefore(E e, Entry<E> entry) {  
  2.     Entry<E> newEntry = new Entry<E>(e, entry, entry.previous);  
  3.     newEntry.previous.next = newEntry;  
  4.     newEntry.next.previous = newEntry;  
  5.     size++;  
  6.     modCount++;  
  7.     return newEntry;  
  8.     }  

LinkedList插入元素的过程(addBefore方法执行操作的图示):
刚刚开始:
空head:



插入元素第一个元素e:



插入第二个元素e2:
指针指向:



删除已经失效的指针效果图:



插入第三个元素e3:

指针指向:





删除已经失效的指针效果图:





示图中,的2X1表示的是,指针指向e2,不再指向e,所以该指向不存在。

LinkedList 的remove方法:
Java代码   收藏代码
  1.    private E remove(Entry<E> e) {  
  2. if (e == header)  
  3.     throw new NoSuchElementException();  
  4.   
  5.        E result = e.element;  
  6. e.previous.next = e.next;  
  7. e.next.previous = e.previous;  
  8.        e.next = e.previous = null;  
  9.        e.element = null;  
  10. size--;  
  11. modCount++;  
  12.        return result;  
  13.    }  

删除前:





删除操作:







程序最后设置e.next,e.previous,e.element为null,虚拟机会回收该快 内存。

LinkedList的addFirst方法(在head之后插入元素)。
Java代码   收藏代码
  1. public void addFirst(E e) {  
  2. addBefore(e, header.next);  
  3.    }  

图示:
1:



2:插入后指针效果图:



3:最后效果图:


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值