www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁 > 公眾號(hào)精選 > 架構(gòu)師社區(qū)
[導(dǎo)讀]LinkedList底層是由雙向鏈表實(shí)現(xiàn)的。鏈表好比火車,每節(jié)車廂包含了車廂和連接下一節(jié)車廂的連接點(diǎn)。而雙向鏈表的每個(gè)節(jié)點(diǎn)不僅有指向下一個(gè)節(jié)點(diǎn)的指針,還有指向上一個(gè)節(jié)點(diǎn)的指針。

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

LinkedList類圖如下:

從面試角度分析LinkedList源碼

LinkedList底層是由雙向鏈表實(shí)現(xiàn)的。鏈表好比火車,每節(jié)車廂包含了車廂和連接下一節(jié)車廂的連接點(diǎn)。而雙向鏈表的每個(gè)節(jié)點(diǎn)不僅有指向下一個(gè)節(jié)點(diǎn)的指針,還有指向上一個(gè)節(jié)點(diǎn)的指針。
LinkedList源碼中有一個(gè)Node靜態(tài)類,源碼如下:

private static class Node<E{
    E item;
    Node next;
    Node prev;

    Node(Node prev, E element, Node next) {
        this.item = element;
        this.next = next;
        this.prev = prev;
    }
}

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

  • item:數(shù)據(jù)

  • next:下一個(gè)節(jié)點(diǎn)的指針

  • prev:上一個(gè)節(jié)點(diǎn)的指針

LinkedList的主要變量如下:

// 集合中的元素?cái)?shù)量
transient int size = 0;

/**
  * 首節(jié)點(diǎn)的指針.
  * Invariant: (first == null && last == null) ||
  *            (first.prev == null && first.item != null)
  */

transient Node first;

/**
  * 尾結(jié)點(diǎn)的指針.
  * Invariant: (first == null && last == null) ||
  *            (last.next == null && last.item != null)
  */

transient Node last;

一、添加元素

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

add()方法源碼:

public boolean add(E e) {
    linkLast(e);
    return true;
}

1.1 尾部插入元素

linkLast()源碼如下:

void linkLast(E e) {
    final Node l = last;
    final Node newNode = new Node<>(l, e, null);
    last = newNode;
    if (l == null)
        first = newNode;
    else
        l.next = newNode;
    size++;
    modCount++;
}

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

假如鏈表中沒有元素

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

從面試角度分析LinkedList源碼

假如鏈表中有元素

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

else
    l.next = newNode;

從面試角度分析LinkedList源碼

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

1.2 頭部插入元素

linkFirst()源碼如下:

private void linkFirst(E e) {
    final Node f = first;
    final Node newNode = new Node<>(null, e, f);
    first = newNode;
    if (f == null)
        last = newNode;
    else
        f.prev = newNode;
    size++;
    modCount++;
}

還是根據(jù)上面的圖來解讀一下源碼,先將第一個(gè)節(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ù)索引元素刪除,除此之外還提供刪除第一個(gè)元素和最后一個(gè)元素的方法,這里我們只分析一下根據(jù)索引刪除的方法。

public E remove(int index) {
    checkElementIndex(index);
    return unlink(node(index));
}

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

node(index)方法源碼:

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

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

unlink(Node x)源碼如下:

unlink(Node x) {
    // assert x != null;
    final E element = x.item;
    final Node next = x.next;
    final Node prev = x.prev;

    if (prev == null) {
        first = next;
    } else {
        prev.next = next;
        x.prev = null;
    }

    if (next == null) {
        last = prev;
    } else {
        next.prev = prev;
        x.next = null;
    }

    x.item = null;
    size--;
    modCount++;
    return element;
}

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

從面試角度分析LinkedList源碼

  1. 假設(shè)刪除的是第一個(gè)元素:則它的prev==NULL,我們需要將他的后一個(gè)元素(圖中的second)作為第一個(gè)元素

  2. 假設(shè)刪除的是最后一個(gè)元素,則它的next==null,我們需要將他的前一個(gè)元素(圖中的second)作為最后一個(gè)元素

  3. 如果是中間的任意元素,則需要將它的前一個(gè)元素的next指針指向它的后一個(gè)元素,同時(shí)將它的后一個(gè)元素的prev指針指向它的前一個(gè)元素。

三、總結(jié)

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

特別推薦一個(gè)分享架構(gòu)+算法的優(yōu)質(zhì)內(nèi)容,還沒關(guān)注的小伙伴,可以長按關(guān)注一下:

從面試角度分析LinkedList源碼

從面試角度分析LinkedList源碼

從面試角度分析LinkedList源碼

長按訂閱更多精彩▼

從面試角度分析LinkedList源碼

如有收獲,點(diǎn)個(gè)在看,誠摯感謝

免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺(tái)僅提供信息存儲(chǔ)服務(wù)。文章僅代表作者個(gè)人觀點(diǎn),不代表本平臺(tái)立場(chǎng),如有問題,請(qǐng)聯(lián)系我們,謝謝!

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動(dòng)力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉