国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

從面試角度分析LinkedList源碼

開發(fā) 前端
LinkedList底層是由雙向鏈表實(shí)現(xiàn)的。鏈表好比火車,每節(jié)車廂包含了車廂和連接下一節(jié)車廂的連接點(diǎn)。而雙向鏈表的每個節(jié)點(diǎn)不僅有指向下一個節(jié)點(diǎn)的指針,還有指向上一個節(jié)點(diǎn)的指針。

[[358239]]

注:本系列文章中用到的jdk版本均為java8

LinkedList類圖如下:

 

LinkedList底層是由雙向鏈表實(shí)現(xiàn)的。鏈表好比火車,每節(jié)車廂包含了車廂和連接下一節(jié)車廂的連接點(diǎn)。而雙向鏈表的每個節(jié)點(diǎn)不僅有指向下一個節(jié)點(diǎn)的指針,還有指向上一個節(jié)點(diǎn)的指針。

在LinkedList源碼中有一個Node靜態(tài)類,源碼如下:

  1. private static class Node<E> { 
  2.     E item; 
  3.     Node<E> next
  4.     Node<E> prev; 
  5.  
  6.     Node(Node<E> prev, E element, Node<E> next) { 
  7.         this.item = element; 
  8.         this.next = next
  9.         this.prev = prev; 
  10.     } 

一個Node節(jié)點(diǎn)包含三個部分,分別是

  • item:數(shù)據(jù)
  • next:下一個節(jié)點(diǎn)的指針
  • prev:上一個節(jié)點(diǎn)的指針

LinkedList的主要變量如下:

  1. // 集合中的元素?cái)?shù)量 
  2. transient int size = 0; 
  3.  
  4. /** 
  5.   * 首節(jié)點(diǎn)的指針. 
  6.   * Invariant: (first == null && last == null) || 
  7.   *            (first.prev == null && first.item != null
  8.   */ 
  9. transient Node<E> first
  10.  
  11. /** 
  12.   * 尾結(jié)點(diǎn)的指針. 
  13.   * Invariant: (first == null && last == null) || 
  14.   *            (last.next == null && last.item != null
  15.   */ 
  16. transient Node<E> last

一、添加元素

LinkedList支持在任意節(jié)點(diǎn)位置添加元素,不僅提供了集合常用的add()方法,還提供了addFirst()和addLast(),add()方法默認(rèn)調(diào)用addLast()方法,也就是默認(rèn)是往鏈表尾部插入元素的。

add()方法源碼:

  1. public boolean add(E e) { 
  2.     linkLast(e); 
  3.     return true

1.1 尾部插入元素

linkLast()源碼如下:

  1. void linkLast(E e) { 
  2.     final Node<E> l = last
  3.     final Node<E> newNode = new Node<>(l, e, null); 
  4.     last = newNode; 
  5.     if (l == null
  6.         first = newNode; 
  7.     else 
  8.         l.next = newNode; 
  9.     size++; 
  10.     modCount++; 

我們來畫張圖演示一下如何給鏈表尾部插入元素:

假如鏈表中沒有元素

對應(yīng)源碼中的if語句,如果沒有元素則新增的這個節(jié)點(diǎn)為鏈表中唯一的一個元素,既是首節(jié)點(diǎn),又是尾結(jié)點(diǎn),前一個元素的指針和后一個元素的指針都是null。這里注意head節(jié)點(diǎn)不是第一個節(jié)點(diǎn),head節(jié)點(diǎn)只是標(biāo)識了這個鏈表的地址。

 

假如鏈表中有元素

對應(yīng)源碼中else語句。先將新增的元素當(dāng)成Last節(jié)點(diǎn),然后將原來的Last節(jié)點(diǎn)的next指向新節(jié)點(diǎn)。

  1. else 
  2.     l.next = newNode; 

 

一圖勝前言,畫個圖是不是什么都明白了。

1.2 頭部插入元素

linkFirst()源碼如下:

  1. private void linkFirst(E e) { 
  2.     final Node<E> f = first
  3.     final Node<E> newNode = new Node<>(null, e, f); 
  4.     first = newNode; 
  5.     if (f == null
  6.         last = newNode; 
  7.     else 
  8.         f.prev = newNode; 
  9.     size++; 
  10.     modCount++; 

還是根據(jù)上面的圖來解讀一下源碼,先將第一個節(jié)點(diǎn)賦值給中間變量f,將新節(jié)點(diǎn)newNode賦值給first節(jié)點(diǎn)。如果鏈表沒有元素,則Last節(jié)點(diǎn)和First節(jié)點(diǎn)都是新插入的節(jié)點(diǎn)newNode,否則,將原來的First節(jié)點(diǎn)的頭指針指向新節(jié)點(diǎn)。

二、刪除元素

LinkedList提供的刪除方法有根據(jù)索引和元素刪除,除此之外還提供刪除第一個元素和最后一個元素的方法,這里我們只分析一下根據(jù)索引刪除的方法。

  1. public E remove(int index) { 
  2.     checkElementIndex(index); 
  3.     return unlink(node(index)); 

checkElementIndex(index)方法就是用來判斷傳輸?shù)乃饕凳欠窈戏ǎ缓戏▌t拋出數(shù)組越界異常。重點(diǎn)來看一下unlink(node(index))方法是如何刪除元素的。

node(index)方法源碼:

node(index)方法就是根據(jù)索引獲取該索引位置的節(jié)點(diǎn)

  1. Node<E> node(int index) { 
  2.     // assert isElementIndex(index); 
  3.     // 如果指定下標(biāo) < 一半元素?cái)?shù)量,則從首結(jié)點(diǎn)開始遍歷 
  4.     // 否則,從尾結(jié)點(diǎn)開始遍歷 
  5.     if (index < (size >> 1)) { 
  6.         Node<E> x = first
  7.         for (int i = 0; i < index; i++) 
  8.             x = x.next
  9.         return x; 
  10.     } else { 
  11.         Node<E> x = last
  12.         for (int i = size - 1; i > index; i--) 
  13.             x = x.prev; 
  14.         return x; 
  15.     } 

unlink(Node x)源碼如下:

  1. E unlink(Node<E> x) { 
  2.     // assert x != null
  3.     final E element = x.item; 
  4.     final Node<E> next = x.next
  5.     final Node<E> prev = x.prev; 
  6.  
  7.     if (prev == null) { 
  8.         first = next
  9.     } else { 
  10.         prev.next = next
  11.         x.prev = null
  12.     } 
  13.  
  14.     if (next == null) { 
  15.         last = prev; 
  16.     } else { 
  17.         next.prev = prev; 
  18.         x.next = null
  19.     } 
  20.  
  21.     x.item = null
  22.     size--; 
  23.     modCount++; 
  24.     return element; 

畫張圖分析一下刪除是如何進(jìn)行的:

 

  1. 假設(shè)刪除的是第一個元素:則它的prev==NULL,我們需要將他的后一個元素(圖中的second)作為第一個元素
  2. 假設(shè)刪除的是最后一個元素,則它的next==null,我們需要將他的前一個元素(圖中的second)作為最后一個元素
  3. 如果是中間的任意元素,則需要將它的前一個元素的next指針指向它的后一個元素,同時將它的后一個元素的prev指針指向它的前一個元素。

三、總結(jié)

 

LinkedList底層是由雙向鏈表實(shí)現(xiàn)的,由于是鏈表實(shí)現(xiàn)的,不僅要存放數(shù)據(jù),還要存放指針,所以內(nèi)存開銷要比ArrayList大,刪除元素不需要移動其他元素,只需要改變指針的指向,因此刪除效率更高,同時它沒有實(shí)現(xiàn)RandomAccess接口,因此使用迭代器遍歷要比for循環(huán)更加高效。LinkedList也支持插入重復(fù)值和空值,同樣也是線程不安全的。

本文轉(zhuǎn)載自微信公眾號「 Java旅途」,可以通過以下二維碼關(guān)注。轉(zhuǎn)載本文請聯(lián)系 Java旅途公眾號。

 

責(zé)任編輯:武曉燕 來源: Java旅途
相關(guān)推薦

2020-12-14 08:03:52

ArrayList面試源碼

2022-03-08 11:29:06

Linux進(jìn)程系統(tǒng)

2021-07-20 10:26:53

源碼底層ArrayList

2018-10-22 14:28:26

面試官數(shù)據(jù)公司

2021-03-15 18:47:25

日志開發(fā)源碼

2014-05-12 10:06:15

面試測試文化360

2018-04-27 14:46:07

面試簡歷程序員

2023-03-13 07:43:51

PHP類型轉(zhuǎn)換

2023-09-11 08:51:23

LinkedList雙向鏈表線程

2016-11-04 10:30:17

微信小程序

2021-09-10 00:34:22

Java 線程啟動

2023-04-14 08:39:01

AQS方法JDK5

2021-09-01 17:51:53

技術(shù)LinkedList 源碼

2017-09-25 16:21:30

Spark on yacluster模式

2021-05-28 11:54:41

區(qū)塊鏈數(shù)據(jù)分析密碼學(xué)角度

2017-04-13 09:45:03

大數(shù)據(jù)新媒體VC

2021-12-09 08:31:01

ReentrantLoAQS

2020-02-04 09:53:05

數(shù)據(jù)安全數(shù)據(jù)泄漏信息安全

2019-04-28 16:10:50

設(shè)計(jì)Redux前端

2022-04-14 07:51:21

MySQL數(shù)據(jù)庫架構(gòu)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

性色av一区二区三区| 91大神影片| 欧美日本中文| 97婷婷大伊香蕉精品视频| 国产午夜亚洲精品一级在线| 亚洲无限av看| 卡通欧美亚洲| 夜夜嗨av色综合久久久综合网| 免费高潮视频95在线观看网站| 欧美va亚洲va香蕉在线| а√中文在线8| 日韩情涩欧美日韩视频| 丁香花在线影院| 亚洲欧美另类自拍| 日本电影久久久| 欧美精品在线极品| 久久99国产精品久久99大师| 日韩免费在线观看视频| 久久久久国产精品| 国产精品一区二区欧美黑人喷潮水 | 成人av免费在线播放| 蜜桃视频一区二区在线观看| 成人久久视频在线观看| 欧美一级片中文字幕| 国产欧美一区二区三区网站| 蜜桃视频网站www| 色欧美片视频在线观看| 好操啊在线观看免费视频| 亚洲精品久久久久久久久久久久久| 日韩伦理在线一区| 美女国内精品自产拍在线播放| 51亚洲精品| 国产精品美女久久久久av超清| 羞羞答答成人影院www| 精品亚洲欧美日韩| 国产剧情一区在线| 国产精品一区二区小说| 欧美性色视频在线| xxxcom在线观看| 久久99久久亚洲国产| 欧美成人激情| 四虎永久免费网站| 亚洲欧美日韩国产一区二区三区 | 高清av一区二区| 亚洲成熟丰满熟妇高潮xxxxx| 亚洲欧美aⅴ...| 在线视频自拍| 国产一区二区三区网站| 欧美三级午夜理伦三级在线观看| 97久久精品午夜一区二区| 蓝色福利精品导航| 黄色成人免费观看| 欧美人与禽zozo性伦| 国产精品原创视频| 91免费版网站入口| 成人午夜精品一区二区三区| 一二三四社区在线视频| 日韩精品久久久久久福利| 久久综合另类图片小说| 免费看成人av| 亚洲欧洲一区二区三区| 91在线中字| 午夜精品在线观看| 久久久青草婷婷精品综合日韩| 成人在线观看a| 欧美剧在线免费观看网站 | 欧美日中文字幕| 亚洲欧美日韩精品久久久| 日本一区二区三区在线不卡| 成人在线app| 欧美资源在线观看| 看国产成人h片视频| 骚视频在线观看| 一区二区三区动漫| 国内精品久久久久久久影视麻豆| 波多野结衣50连登视频| 欧美日高清视频| 五月综合久久| avav在线播放| 欧美日韩电影一区| 日韩丝袜视频| 欧美日韩午夜爽爽| 色综合天天视频在线观看| 人人精品久久| 亚洲欧美影院| 欧美午夜精品电影| 中国av一区| 香港三级韩国三级日本三级| 欧美日韩一区 二区 三区 久久精品| 大香伊人久久精品一区二区 | 男人和女人啪啪网站| 欧美人与性动xxxx| 日韩欧美一区免费| 91视频免费版污| 亚洲免费小视频| 一本色道久久综合亚洲精品不卡| 神马久久影视大全| 久久久久www| 国产精品自产自拍| 免费在线观看的电影网站| 成人免费在线视频网址| 国产精品欧美一级免费| 伊人久久精品一区二区三区| 日韩精品久久久毛片一区二区| 色一情一伦一子一伦一区| 亚洲素人在线| 9久久婷婷国产综合精品性色 | 日韩av电影在线免费播放| 不卡影院免费观看| 日本不卡网站| 少妇特黄a一区二区三区| 欧美日韩亚洲综合在线| 天天做天天爱天天综合网2021| 成人短剧在线观看| 欧美精品成人91久久久久久久| 成人精品鲁一区一区二区| 交100部在线观看| 欧美极品一区| 欧美一区二区在线看| av不卡在线| 久久精品视频免费看| 久久国产精品 国产精品| 欧美日韩精品一区二区三区蜜桃| 亚洲国产精品久久久天堂| 伊人av免费在线观看| 亚洲一区免费网站| 欧美天堂一区二区三区| 欧美日韩ab| 日韩精品黄色| 欧美日韩国产综合视频在线| 欧美日韩精品电影| 国产色综合网| 丰满诱人av在线播放| 国产女人18毛片| 日韩中文在线视频| 国产欧美一区二区精品性| 女人av一区| 日韩在线无毛| 欧美日韩综合精品| 亚洲精品小视频在线观看| 99久久精品国产毛片| 99久久免费精品国产72精品九九| 亚洲欧美在线精品| 日本一区二区在线播放| 亚洲伊人伊色伊影伊综合网| 欧美久久一级| 男男gaygays亚洲| 妞干网在线视频观看| 久久久久久国产免费| 亚洲国产日韩综合久久精品| 欧美日韩亚洲国产精品| 国产探花在线观看| 国产日韩一区二区在线观看| 国产999在线观看| 欧美日韩一区二区三区四区五区| 蜜桃视频在线观看一区二区| 亚洲精品成a人ⅴ香蕉片| 99热在线免费观看| 国产精品jizz视频| 日韩电影免费在线观看中文字幕| 久久夜色精品一区| 仙踪林久久久久久久999| 欧美xxxx黑人又粗又长| a在线视频观看| 成人网中文字幕| 亚洲国产成人精品一区二区 | 永久免费网站视频在线观看| 精品综合久久久久久97| 精品久久香蕉国产线看观看亚洲| 亚洲三级国产| 日日狠狠久久| 中文字幕国产在线| 一区二区三区四区视频在线| 隔壁老王国产在线精品| 欧美日韩在线观看一区二区 | 日韩免费中文专区| 欧美裸体xxxx极品少妇| 日本黄色一区二区| proumb性欧美在线观看| 99精品视频在线| 国产欧洲在线| 日本高清视频网站www| 日韩中文字幕一区| 久久久之久亚州精品露出| 制服丝袜在线91| 国产精品欧美一区二区三区| 翔田千里一区二区| 日韩精品一级| a视频在线免费看| 高清成人av| 大地资源第二页在线观看高清版| 日本aⅴ大伊香蕉精品视频| 亚洲国模精品一区| 亚洲国产精品久久艾草纯爱| 国产精品一区二区在线观看不卡 | 777精品视频| 精品国产乱码久久久久久影片| 亚洲欧美精品午睡沙发| 国产美女视频91| 综合在线视频|