Yikun

  • 主页
  • 文章
  • 项目
  • 关于我
所有分类 友情链接

Yikun

  • 主页
  • 文章
  • 项目
  • 关于我

Java LinkedList工作原理及实现

Apr 5 2015

1. 概述

以双向链表实现。链表无容量限制,但双向链表本身使用了更多空间,也需要额外的链表指针操作。

按下标访问元素–get(i)/set(i,e) 要悲剧的遍历链表将指针移动到位(如果i>数组大小的一半,会从末尾移起)。

插入、删除元素时修改前后节点的指针即可,但还是要遍历部分链表的指针才能移动到下标所指的位置,只有在链表两头的操作–add(), addFirst(),removeLast()或用iterator()上的remove()能省掉指针的移动。

LinkedList是一个简单的数据结构,与ArrayList不同的是,他是基于链表实现的。

Doubly-linked list implementation of the List and Deque interfaces. Implements all optional list operations, and permits all elements (including null).

1
2
3
4
LinkedList<String> list = new LinkedList<String>();
list.add("语文: 1");
list.add("数学: 2");
list.add("英语: 3");

结构也相对简单一些,如下图所示:
linkedlist

2. set和get函数

1
2
3
4
5
6
7
8
9
10
11
12
public E set(int index, E element) {
checkElementIndex(index);
Node<E> x = node(index);
E oldVal = x.item;
x.item = element;
return oldVal;
}

public E get(int index) {
checkElementIndex(index);
return node(index).item;
}

这两个函数都调用了node函数,该函数会以O(n/2)的性能去获取一个节点,具体实现如下所示:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
Node<E> node(int index) {
// assert isElementIndex(index);

if (index < (size >> 1)) {
Node<E> x = first;
for (int i = 0; i < index; i++)
x = x.next;
return x;
} else {
Node<E> x = last;
for (int i = size - 1; i > index; i--)
x = x.prev;
return x;
}
}

就是判断index是在前半区间还是后半区间,如果在前半区间就从head搜索,而在后半区间就从tail搜索。而不是一直从头到尾的搜索。如此设计,将节点访问的复杂度由O(n)变为O(n/2)。

参考资料

LinkedList (Java Platform SE 8)

赏

有收获再赏哦

支付宝
微信
  • Java

扫一扫,分享到微信

微信分享二维码
Java TreeMap工作原理及实现
Java ArrayList工作原理及实现
0 comments
Anonymous
Markdown is supported

Be the first person to leave a comment!

© 2021 Yikun
Hexo Theme Yilia by Litten
  • 所有分类
  • 友情链接

tag:

  • 随笔
  • Nova
  • OpenStack
  • C/C++
  • Git
  • Java
  • Cinder
  • Python
  • Nginx
  • 数据库
  • vim
  • 网络
  • 系统
  • 大数据
  • Linux
  • OpenSource
  • ARM

    缺失模块。
    1、请确保node版本大于6.2
    2、在博客根目录(注意不是yilia根目录)执行以下命令:
    npm i hexo-generator-json-content --save

    3、在根目录_config.yml里添加配置:

      jsonContent:
        meta: false
        pages: false
        posts:
          title: true
          date: true
          path: true
          text: false
          raw: false
          content: false
          slug: false
          updated: false
          comments: false
          link: false
          permalink: false
          excerpt: false
          categories: false
          tags: true
    

  • 如何在上游贡献代码(Github篇)?

    2021-04-27

    #OpenSource

  • 大文件在Github和Gitee上传的建议

    2020-11-24

    #Git#OpenSource

  • 从数据压缩切入看MapReduce的全流程

    2020-08-20

    #大数据

  • 搭建Hadoop Yarn环境 (ARM)

    2020-08-15

    #大数据#ARM

  • 让压缩库ZSTD在ARM上更顺滑

    2020-05-20

    #OpenSource#ARM

  • 让Github Action在你自己的机器上跑起来

    2020-04-17

    #Git

  • 从Java Math底层实现看Arm与x86的差异

    2020-04-10

    #Java

  • Github Action入门指南

    2020-02-28

    #Git

  • 巧用Github Action同步代码到Gitee

    2020-01-17

    #Git

  • 源于鲲鹏,回归社区:GNU Glibc的ARM优化小记

    2019-12-30

    #ARM

  • OpenLab快速使用指南

    2019-04-12

    #OpenStack

  • [Placement深度探索] 共享、嵌套、分组模型深度解析

    2018-08-01

    #OpenStack

  • Python3内建函数扫盲

    2018-06-15

    #Python

  • Cell v2近期相关改进整理

    2018-06-06

    #Nova#OpenStack

  • oslo.db中的死锁重试机制优化

    2018-04-19

    #OpenStack#数据库

  • [Placement深度探索] Granular Resource Request Syntax

    2018-04-02

    #Nova#OpenStack

  • Nova Scheduler Team Meeting跟踪(三月)

    2018-03-31

    #Nova#OpenStack

  • Nova Scheduler Team Meeting跟踪(二月)

    2018-02-07

    #Nova#OpenStack

  • Nova Scheduler Team Meeting跟踪(一月)

    2018-02-01

    #Nova#OpenStack

  • Nova Scheduler Team Meeting跟踪

    2018-02-01

    #Nova#OpenStack

  • [Placement深度探索] Resource Provider中的并发控制机制

    2018-01-23

    #Nova#OpenStack

  • [Placement深度探索] Nested Resource Providers

    2017-12-26

    #Nova#OpenStack

  • [Placement深度探索] Get Allocation Candidates

    2017-12-25

    #Nova#OpenStack

  • 一个死锁问题的深入探究

    2017-12-13

    #Nova#OpenStack#Python

  • Nova调度相关特性理解与梳理

    2017-12-06

    #Nova#OpenStack

  • 跨Cell场景下查询的那些事儿

    2017-11-16

    #Nova#OpenStack

  • [译] An Update on the Placement API and Scheduler plans for Queens

    2017-10-25

    #Nova#OpenStack

  • OpenStack Nova虚拟机冷迁移流程解析

    2017-10-11

    #Nova#OpenStack

  • OpenStack Nova虚拟机创建流程解析

    2017-09-27

    #Nova#OpenStack

  • [译] Simpler Road to Cinder Active-Active

    2017-08-16

    #OpenStack#Cinder

  • 一次有关OpenStack请求的性能问题分析

    2016-07-22

    #OpenStack

  • 一致性哈希算法的理解与实践

    2016-06-09

    #系统

  • 理解Python中的“with”

    2016-04-15

    #Python

  • 存储数据包的一生

    2016-04-03

    #系统

  • OpenStack源码分析-Cinder中的调度机制

    2016-03-04

    #Cinder

  • OpenStack源码分析-Service启动流程

    2016-03-04

    #OpenStack#Cinder

  • OpenStack源码分析-挂载卷流程

    2016-03-04

    #Cinder

  • 优雅地调试OpenStack

    2016-02-22

    #OpenStack

  • OpenStack源码分析-Cinder删除卷流程

    2016-02-21

    #OpenStack#Cinder

  • OpenStack源码分析-Cinder创建卷流程

    2016-02-14

    #OpenStack#Cinder

  • 搭建OpenStack开发环境

    2016-02-09

    #OpenStack

  • 存储知识学习

    2016-02-03

    #OpenStack#Cinder

  • [译]Internationalization

    2016-01-22

    #Nova

  • [译]Virtual Machine States and Transitions

    2016-01-20

    #Nova

  • 2015,再见

    2016-01-01

    #随笔

  • Python3源码学习-整型

    2015-12-21

    #Python

  • Python3源码学习-类型

    2015-12-20

    #Python

  • Python3源码学习-编译Python源码

    2015-12-20

    #Python

  • Python3源码学习-对象

    2015-12-03

    #Python

  • 网络知识拾遗

    2015-11-23

    #网络

  • [译]Threading model

    2015-11-19

    #OpenStack

  • [译]Host Aggregates

    2015-10-17

    #Nova#OpenStack

  • [译]Scope of the Nova project

    2015-10-16

    #Nova#OpenStack

  • [译]Nova System Architecture

    2015-10-15

    #Nova#OpenStack

  • 读《OpenStack设计与实现》

    2015-10-08

    #OpenStack

  • OpenStack概览

    2015-10-04

    #OpenStack

  • 再见,北京

    2015-06-18

    #随笔

  • 一个简单的网络数据包工具——Packet Assistant

    2015-06-15

    #Python#网络

  • Spring IOC核心源码学习

    2015-05-28

    #Java

  • 学习awk和sed

    2015-05-23

    #Linux

  • 利用Shell进行Web日志分析

    2015-05-20

    #Linux

  • 重新学习Shell

    2015-05-19

    #Linux

  • Java CopyOnWriteArrayList工作原理及实现

    2015-04-28

    #Java

  • Git常用操作总结

    2015-04-24

    #Git

  • Java EnumMap工作原理及实现

    2015-04-23

    #Java

  • C语言中移位操作符优先级的坑

    2015-04-18

    #C/C++

  • Java ArrayDeque工作原理及实现

    2015-04-11

    #Java

  • Java TreeSet工作原理及实现

    2015-04-10

    #Java

  • Java LinkedHashSet工作原理及实现

    2015-04-09

    #Java

  • Java HashSet工作原理及实现

    2015-04-08

    #Java

  • Java PriorityQueue工作原理及实现

    2015-04-07

    #Java

  • Java TreeMap工作原理及实现

    2015-04-06

    #Java

  • Java LinkedList工作原理及实现

    2015-04-05

    #Java

  • Java ArrayList工作原理及实现

    2015-04-04

    #Java

  • 如何设计实现一个LRU Cache?

    2015-04-03

    #系统

  • Java LinkedHashMap工作原理及实现

    2015-04-02

    #Java

  • Java HashMap工作原理及实现

    2015-04-01

    #Java

  • Java集合框架

    2015-03-31

    #Java

  • 定时器管理实现与初探

    2015-03-08

    #C/C++#系统

  • 自增运算符的反汇编

    2015-02-08

    #C/C++

  • 搭建Git服务器

    2015-02-05

    #Git

  • 排序算法总结

    2014-11-20

  • nginx的连接池

    2014-04-17

    #Nginx

  • nginx建立连接过程分析

    2014-04-01

    #Nginx

  • nginx的事件主体分析

    2014-03-26

    #Nginx

  • nginx的事件初始化与框架

    2014-03-21

    #Nginx

  • 我的vim配置

    2014-03-19

    #vim

  • nginx中channel机制

    2014-03-16

    #Nginx

  • nginx启动流程分析

    2014-03-13

    #Nginx

  • JNI调试方法

    2013-02-27

    #Java

  • 岁月如梭, 我的2012

    2012-12-27

    #随笔

  • MarkDown格式备注

    2012-12-26

  • Hello World

    2012-12-21

    #随笔

  • Linux Record

    2012-12-06

  • 从实践中一路走来

    2012-11-17

    #随笔

  • 渐变

    2011-05-18

    #随笔

  • 很久很久

    2011-03-22

    #随笔

  • 写一篇日志

    2010-10-05

    #随笔

  • 静夕思

    2010-07-10

    #随笔