LinkedList - 好一个双向链表
LinkedList是常用的集合结构之一,数据存储结构为链式存储,每个节点都有元素、前指针和后指针,指针指向了前节点和后节点的位置。同是LinkedList也是一个队列,实现了Deque接口,Deque接口继承了Queue接口。
1.7以前为双向循环链表,之后没有循环了哦。
队列出入顺序为FIFO,插入的位置是队列的尾部,而移出的位置是队头,Queue接口提供了offer()入列,和poll()出列的方法。
LinkedList的add(E e)方法:
public boolean add(E var1) {
this.linkLast(var1);
return true;
}
再来看this.linkLast(var1)方法:
void linkLast(E var1) {
LinkedList.Node var2 = this.last; //内部初始提供了first和last两个节点
LinkedList.Node var3 = new LinkedList.Node(var2, var1, (LinkedList.Node)null); //构造一个新的Last节点,前指针指向原来的last节点var2 ,后指针为null
this.last = var3; //将var3 赋值给last节点
if (var2 == null) { //var2 为空 表示整个LinkedList没有任何元素,第一次加入,此时first节点和last节点都为var3
this.first = var3;
} else { //不为空则将原last节点的后指针指向var3
var2.next = var3;
}
++this.size;
++this.modCount;
}
LinkedList的add(int var1, E e)方法
public void add(int var1, E var2) {
this.checkPositionIndex(var1); //var1范围检查
if (var1 == this.size) { //如果var1==size 则直接再末尾添加一个节点
this.linkLast(var2);
} else {
this.linkBefore(var2, this.node(var1)); //这里node方法找到var1下标对应的元素,在此元素前面插入新节点
}
}
LinkedList.Node<E> node(int var1) {
LinkedList.Node var2;
int var3;
if (var1 < this.size >> 1) { //判断var1和中位值的大小,小于则从first节点开始向后遍历,大于则从last节点开始向前遍历
var2 = this.first;
for(var3 = 0; var3 < var1; ++var3) {
var2 = var2.next;
}
return var2;
} else {
var2 = this.last;
for(var3 = this.size - 1; var3 > var1; --var3) {
var2 = var2.prev;
}
return var2;
}
}
void linkBefore(E var1, LinkedList.Node<E> var2) {
LinkedList.Node var3 = var2.prev;
LinkedList.Node var4 = new LinkedList.Node(var3, var1, var2);
var2.prev = var4;
if (var3 == null) { //若只有一个元素,则first节点为null
this.first = var4;
} else {
var3.next = var4;
}
++this.size;
++this.modCount;
}
再来看一下重写的offer和poll方法
public boolean offer(E var1) {
return this.add(var1);
}
插入的时候调用的是linkLast方法,及last节点为入列口,是队尾
public E poll() {
LinkedList.Node var1 = this.first;
return var1 == null ? null : this.unlinkFirst(var1);
}
移除的时候调用了this.unlinkFirst(var1)方法
private E unlinkFirst(LinkedList.Node<E> var1) {
Object var2 = var1.item; //获取first节点的数据返回
LinkedList.Node var3 = var1.next; //first节点的last节点
var1.item = null; //help GC
var1.next = null; //first节点的next节点指向null
this.first = var3; //现在first节点为var3
if (var3 == null) { //如果为null 则说明最开始first没有next元素,链表为空或者只有一个first元素,现在移除了first元素,链表里没有元素了,last为null
this.last = null;
} else { //first节点的prev节点为null
var3.prev = null;
}
--this.size;
++this.modCount;
return var2;
}
LinkedList - 好一个双向链表的更多相关文章
- 跟踪LinkedList源码,通过分析双向链表实现原理,自定义一个双向链表
1.LinkedList实现的基本原理 LinkedList是一个双向链表,它主要有两个表示头尾节点的成员变量first .last,因其有头尾两个节点,所以从头或从尾操作数据都非常容易快捷.Lin ...
- 使用LinkedList模拟一个堆栈或者队列数据结构
使用LinkedList模拟一个堆栈或者队列数据结构. 堆栈:先进后出 如同一个杯子. 队列:先进先出 如同一个水管. import java.util.LinkedList; public cl ...
- Java LinkedList特有方法程序小解 && 使用LinkedList 模拟一个堆栈或者队列数据结构。
package Collection; import java.util.LinkedList; /* LinkedList:特有的方法 addFirst()/addLast(); getFirst( ...
- C语言一个双向链表的实现
首先编写头文件,头文件里做相关的定义和声明,DList.h内容如下: #ifndef DList_H #define DList_H typedef int Item; typedef struct ...
- Java实现一个双向链表的倒置功能
题目要求:Java实现一个双向链表的倒置功能(1->2->3 变成 3->2->1) 提交:代码.测试用例,希望可以写成一个Java小项目,可以看到单元测试部分 该题目的代码, ...
- Queue接口的实现类竟然有一个是LinkedList,一个是优先队列(同一个接口,只改了不同的实现类,附源码)
输出是: Queue接口底层换一个实现类,照样的是调用Queue接口中的方法 import java.util.HashMap; import java.util.LinkedList; import ...
- 用 LinkedList 实现一个 java.util.Stack 栈
用 LinkedList 实现一个 java.util.Stack 栈 import java.util.LinkedList; public class Stack<E> { priva ...
- 【Java基础】用LinkedList实现一个简单栈的功能
栈的基本功能 栈的最基本功能是保障后进先出,然后在此基础上可以对在栈中的对象进行弹入弹出,此外,在弹出时,如果栈为空,则会报错,所以还需要提供获取当前栈大小的方法. 构造存储对象Student /** ...
- java 使用LinkedList模拟一个堆栈或者队列数据结构
近期在复习下java基础,看了下java基础,在看到集合时突然发现想起来曾经面试有一道笔试题:模拟一个堆栈或者队列数据结构,当时还没做出来,今天就写一下,首先得明确堆栈和队列的数据结构 堆栈:先进后出 ...
随机推荐
- Split CSV/TXT file
void Main(){ var path = @"c:\sourceGit\speciesLatLon.txt"; var inputLines = File.ReadAllLi ...
- [转]MTK6252 11B添加模块、task实例
原网址 http://blog.sina.com.cn/s/blog_6b2328a201014l26.html ###############模块的添加################## 1 ...
- Java后端面试的一切技巧和常见的问题经验总结
原文地址:cnblogs.com/JavaArchitect/p/10011253.html 上周,密集面试了若干位Java后端候选人,工作经验在3到5年间.我的标准其实不复杂(适用90%小小小公司, ...
- Mac系统如何显示隐藏文件?
显示全部文件 defaults write com.apple.finder AppleShowAllFiles -bool true osascript -e 'tell application & ...
- 004之MFCSocket同步编程(指针机制)
异步与同步通信相比较,前者是非阻塞模式,后者是阻塞模式.有关两者差异在此博主中有详细讲解,推荐:https://www.cnblogs.com/wzsblogs/p/4671559.html. 采用同 ...
- Binder吐槽学习
通过 ProcessState::self()->startThreadPool()新加了一个Binder线程,然后通过IPCThreadState::self()->joinThread ...
- 安装VMware tools
1.发现在vmware中无法复制粘贴,经查询后Centos精简版是没有VMware tools的.2.df是用来看磁盘空间使用情况的.3.rpm包的格式:name+version(主版本+此版本+修正 ...
- ajax、json、jsonp
这章分享下ajax.json.jsonp的学习记录,不得不说这真是些令人激动的技术. 推荐文章: https://segmentfault.com/a/1190000012469713 http:// ...
- unittest框架(惨不忍睹低配版)
根据我上个随笔的unittest框架优化得来,虽然对于smtp模块还是有点迷糊,不过还是勉强搭建运行成功了,还是先上代码: #login_test.py import requests class L ...
- 浏览器登录EBS系统遇到问题总结
1.可以登录EBS系统,但是职责位置为空白 这是兼容性视图问题,将ERP域名加入兼容性视图列表即可. 加入即可: 2.可以登录EBS系统,但是职责位置显示 “undefined” 这也是兼容性视图问题 ...