一,前言  

  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的更多相关文章

  1. JDK 1.8 源码阅读和理解

    根据 一篇文章教会你,如何做到招聘要求中的“要有扎实的Java基础” 的指引,决定开始阅读下JDK源码. 本文将作为源码阅读总纲 一.精读部分 java.io java.lang java.util ...

  2. JDK 1.8源码阅读 TreeMap

    一,前言 TreeMap:基于红黑树实现的,TreeMap是有序的. 二,TreeMap结构 2.1 红黑树结构 红黑树又称红-黑二叉树,它首先是一颗二叉树,它具体二叉树所有的特性.同时红黑树更是一颗 ...

  3. JDK 1.8源码阅读 HashMap

    一,前言 HashMap实现了Map的接口,而Map的类型是成对出现的.每个元素由键与值两部分组成,通过键可以找对所对应的值.Map中的集合不能包含重复的键,值可以重复:每个键只能对应一个值. 存储数 ...

  4. JDK 1.8源码阅读 HashSet

    一,前言 类实现Set接口,由哈希表支持(实际上是一个 HashMap集合).HashSet集合不能保证的迭代顺序与元素存储顺序相同.HashSet集合,采用哈希表结构存储数据,保证元素唯一性的方式依 ...

  5. JDK 1.8源码阅读 ArrayList

    一,前言 ArrayList是Java开发中使用比较频繁的一个类,通过对源码的解读,可以了解ArrayList的内部结构以及实现方法,清楚它的优缺点,以便我们在编程时灵活运用. 二,ArrayList ...

  6. jdk源码阅读笔记-LinkedHashMap

    Map是Java collection framework 中重要的组成部分,特别是HashMap是在我们在日常的开发的过程中使用的最多的一个集合.但是遗憾的是,存放在HashMap中元素都是无序的, ...

  7. jdk源码阅读笔记-HashSet

    通过阅读源码发现,HashSet底层的实现源码其实就是调用HashMap的方法实现的,所以如果你阅读过HashMap或对HashMap比较熟悉的话,那么阅读HashSet就很轻松,也很容易理解了.我之 ...

  8. JDK部分源码阅读与理解

    本文为博主原创,允许转载,但请声明原文地址:http://www.coselding.cn/article/2016/05/31/JDK部分源码阅读与理解/ 不喜欢重复造轮子,不喜欢贴各种东西.JDK ...

  9. JDK源码阅读(三):ArraryList源码解析

    今天来看一下ArrayList的源码 目录 介绍 继承结构 属性 构造方法 add方法 remove方法 修改方法 获取元素 size()方法 isEmpty方法 clear方法 循环数组 1.介绍 ...

随机推荐

  1. Oracle分析函数-nulls first/nulls last

    select * from criss_sales; 通过rank().dense_rank().row_number()对记录进行全排列.分组排列取值但有时候,会遇到空值的情况,空值会影响得到的结果 ...

  2. Smart Link

    Smart Link通过两个接口相互配合工作来实现功能.这样的一对接口组成了一个Smart Link组.为了区别一个Smart Link组中的两个接口,我们将其中的一个叫做主接口,另一个叫做从接口.同 ...

  3. 四大中三家已面向客户推出机器人业务解决方案?别逗了,先用机器人自我革命吧! post by 上海嘉冰信息技术

    近日,四大会计师事务所推出的机器人财务及业务解决方案的话题引爆朋友圈.鉴于该话题的前沿性以及对财务及业务领域从业人员未来职业发展有巨大的影响,引起热门讨论在所难免.小编先来汇总下目前国际四大会计师事务 ...

  4. go for-range中的循环变量

    测试的时候发现一个有意思的地方,就是go始终利用同一块内存来接收集合中的一个值,只是在每次循环的时候重新赋值而已. package main import (     "fmt" ...

  5. SortedSet的实现类是TreeSet:它的作用是字为添加到TreeSet中的元素排序。

      SortedSet可自动为元素排序. SortedSet的实现类是TreeSet:它的作用是字为添加到TreeSet中的元素排序.   练习:自定义类用TreeSet排序. 与HashSet不同, ...

  6. flume学习笔记——安装和使用

    Flume是一个分布式.可靠.和高可用的海量日志聚合的系统,支持在系统中定制各类数据发送方,用于收集数据:同时,Flume提供对数据进行简单处理,并写到各种数据接受方(可定制)的能力. Flume是一 ...

  7. IDEA阅读spring源码并调试

    目标:搭建起Spring源码阅读和代码调试跟踪的环境,顺便建立一个简单的Demo,能够调试Spring的源代码 本节,主要介绍一下Spring源码阅读和调试的相关环境搭建,并使用MVN创建一个非常简单 ...

  8. VS2013-2017 舒服的字体设置和背景色

    使用字体:Fixedsys Excelsior 3.01 1.如果没有安装字体的话,首先下载字体:http://www.fixedsysexcelsior.com/ 2.安装字体:控制面板 -> ...

  9. Linux网络设备驱动 _驱动模型

    Linux素来以其强大的网络功能著名,同时, 网络设备也作为三大设备之一, 成为Linux驱动学习中必不可少的设备类型, 此外, 由于历史原因, Linux并没有强制对网络设备贯彻其"一切皆 ...

  10. python if,for,while

    # -*- coding:utf-8 -*- # 第四章 if for while #布尔逻辑 print True == False print True and False print True ...