JDK 1.8源码阅读 LinkList
一,前言
LinkedList是一个实现了List接口和Deque接口的双端链表。有关索引的操作可能从链表头开始遍历到链表尾部,也可能从尾部遍历到链表头部,这取决于看索引更靠近哪一端。 LinkedList不是线程安全的。
二,LinkList结构
LinkList内部是一个双向列表的结构,如下图所示。

三,LinkList源码阅读
3.1 LinkList的继承关系

从继承关系可以看出,LinkedList不但继承了List接口同时也继承了Queue接口。
3.2 LinkedList的构造方法
public LinkedList() {} // 空参构造
public LinkedList(Collection<? extends E> c) {
this();
addAll(c);
} // 带参构造,传入一个集合对象
3.3 LinkedList的常用方法
public E getFirst() {} // 获取第一个元素
public E getLast() {} // 获取最后一个节点元素
public E removeFirst() {} // 删除最开始节点元素,并将改元素返回
public E removeLast() {} // 删除最后节点元素,并将改元素返回
public void addFirst(E e) {} // 最前面添加节点元素
public void addLast(E e) {} //添加最后节点元素
public boolean contains(Object o) {} // 判断元素是否存在
public int size() {} // 返回集合长度
public boolean add(E e) {} // 最末尾添加
public boolean remove(Object o) {} // 最末尾删除
public boolean addAll(Collection<? extends E> c) {} // 将一个集合添加到Linkedlist
public boolean addAll(int index, Collection<? extends E> c) {} // 指定索引位置后开始添加集合
public void clear() {} // 清空
// Positional Access Operations
public E get(int index) {} // 更具索引获取数据
public E set(int index, E element) {} // 将指定位置的数字进行替换
public void add(int index, E element) {} // 指定索引添加
public E remove(int index) {} // 删除指定索引位置数据
// Search Operations
public int indexOf(Object o) {} // 返回指定元素的索引
public int lastIndexOf(Object o) {} // 最后一次出现该元素的索引
// Queue operations. 队列方式,增删更快
public E peek() {} // 返回第一个,该方法笔者测试了感觉没什么用,可能没有理解深刻。
public E element() {} // 返回第一个元素
public E poll() {} // 返回和删除第一个元素
public E remove() {} // 返回和删除第一个元素
public boolean offer(E e) {} // 最后面添加元素
public boolean offerFirst(E e) {} // 开始添加元素
public boolean offerLast(E e) {} // 最后添加元素
public E peekFirst() {} // 返回第一个
public E peekLast() {} // 返回最后一个
public E pollFirst() {} // 返回和删除第一个元素
public E pollLast() {} // 返回和删除最后元素
public void push(E e) {} // 前面添加
public E pop() {} // 删除并返回第一个
public boolean removeFirstOccurrence(Object o) {} // 删除第一个
public boolean removeLastOccurrence(Object o) {} // 删除最后一个
public ListIterator<E> listIterator(int index) {}
/**
* @since 1.6
*/
public Iterator<E> descendingIterator() {} // 转换迭代对象
public Object clone() {} // 复制一个
public Object[] toArray() {} // 转化成数组
@SuppressWarnings("unchecked")
public <T> T[] toArray(T[] a) {}
/**
* @since 1.8
*/
@Override
public Spliterator<E> spliterator() {}
从方法中发现,有很多相同功能的方法,但是在效率上会有一定的差别。用队列的方式进行添加效率更高。
四,总结
LinkedList是基于双端链表的List,其内部的实现源于对链表的操作,所以适用于频繁增加、删除的情况;该类不是线程安全的;另外,由于LinkedList实现了Queue接口,所以LinkedList不止有队列的接口,还有栈的接口,可以使用LinkedList作为队列和栈的实现。
JDK 1.8源码阅读 LinkList的更多相关文章
- JDK 1.8 源码阅读和理解
根据 一篇文章教会你,如何做到招聘要求中的“要有扎实的Java基础” 的指引,决定开始阅读下JDK源码. 本文将作为源码阅读总纲 一.精读部分 java.io java.lang java.util ...
- JDK 1.8源码阅读 TreeMap
一,前言 TreeMap:基于红黑树实现的,TreeMap是有序的. 二,TreeMap结构 2.1 红黑树结构 红黑树又称红-黑二叉树,它首先是一颗二叉树,它具体二叉树所有的特性.同时红黑树更是一颗 ...
- JDK 1.8源码阅读 HashMap
一,前言 HashMap实现了Map的接口,而Map的类型是成对出现的.每个元素由键与值两部分组成,通过键可以找对所对应的值.Map中的集合不能包含重复的键,值可以重复:每个键只能对应一个值. 存储数 ...
- JDK 1.8源码阅读 HashSet
一,前言 类实现Set接口,由哈希表支持(实际上是一个 HashMap集合).HashSet集合不能保证的迭代顺序与元素存储顺序相同.HashSet集合,采用哈希表结构存储数据,保证元素唯一性的方式依 ...
- JDK 1.8源码阅读 ArrayList
一,前言 ArrayList是Java开发中使用比较频繁的一个类,通过对源码的解读,可以了解ArrayList的内部结构以及实现方法,清楚它的优缺点,以便我们在编程时灵活运用. 二,ArrayList ...
- jdk源码阅读笔记-LinkedHashMap
Map是Java collection framework 中重要的组成部分,特别是HashMap是在我们在日常的开发的过程中使用的最多的一个集合.但是遗憾的是,存放在HashMap中元素都是无序的, ...
- jdk源码阅读笔记-HashSet
通过阅读源码发现,HashSet底层的实现源码其实就是调用HashMap的方法实现的,所以如果你阅读过HashMap或对HashMap比较熟悉的话,那么阅读HashSet就很轻松,也很容易理解了.我之 ...
- JDK部分源码阅读与理解
本文为博主原创,允许转载,但请声明原文地址:http://www.coselding.cn/article/2016/05/31/JDK部分源码阅读与理解/ 不喜欢重复造轮子,不喜欢贴各种东西.JDK ...
- JDK源码阅读(三):ArraryList源码解析
今天来看一下ArrayList的源码 目录 介绍 继承结构 属性 构造方法 add方法 remove方法 修改方法 获取元素 size()方法 isEmpty方法 clear方法 循环数组 1.介绍 ...
随机推荐
- iis asp.net4.0注册
asp.net4.0下载地址:https://download.microsoft.com/download/9/5/A/95A9616B-7A37-4AF6-BC36-D6EA96C8DAAE/do ...
- golang:常量
今天写代码的时候才发现,go语言里面的常量不能是数组(例如:[2]byte) 于是想查一下资料搞清楚到底是什么原因导致的,从effective go查到如下介绍: 但是这里也仅仅就是介绍了一下常量类型 ...
- C语言 · 数的划分
算法训练 数的划分 时间限制:1.0s 内存限制:256.0MB 锦囊1 使用动态规划. 锦囊2 用F[i,j,k]表示将i划分成j份,最后一份为k的方案数,则F[i,j,k]= ...
- [转] tomcat 7/8 启动非常慢的解决方法
在日志中发现启动慢的地方: -- ::] INFO o.s.c.s.DefaultLifecycleProcessor - Starting beans -- ::] INFO o.s.web.con ...
- log4net 如何关闭Nhibernate产生的大量日志
[参考文献]Log4Net指南 非常完善的Log4net详细说明 C# 使用Log4Net记录日志(进阶篇) 此问题困扰良久 良久 良久 appender filter ,show_sql false ...
- Cesium简单使用
CesiumJS是一个基于javascript的浏览器器3d地图引擎 下载 https://cesiumjs.org/downloads/ 下载的Cesium-1.56.1,解压后的结构为 1.设置W ...
- docker 应用-2(Dockerfile 编写以及镜像保存提交)
我们可以从docker hub上pull别人的镜像,也可以将容器进行修改,然后commit镜像,并把镜像push到docker hub上被被人使用.但是,直接pull或者push镜像的方式太过笨重,尤 ...
- 【Oracle】PL/SQL 显式游标、隐式游标、动态游标
在PL/SQL块中执行SELECT.INSERT.DELETE和UPDATE语句时,Oracle会在内存中为其分配上下文区(Context Area),即缓冲区.游标是指向该区的一个指针,或是命名一个 ...
- tomcat启动出错 invalid LOC header
tomcat启动出错 invalid LOC header,run as maven test 没有报错,只有警告: 'build.plugins.plugin.version' for org.ap ...
- 进程池原理及效率测试Pool
为什么会有进程池的概念? 当我们开启50个进程让他们都将100这个数减1次减到50,你会发现特别慢! 效率问题,原因: 1,开辟内存空间.因为每开启一个进程,都会开启一个属于这个进程池的内存空间,因为 ...