Java中LinkedList筆記

來源:互聯網
上載者:User

標籤:

之前寫程式似乎也沒有怎麼關注過底層的結構,最近正好遇到了鏈表的問題,於是仔細閱讀了Java中鏈表的實現LinkedList

簡單記錄一下看完的總結:

1.LinkedList中定義了一個類型Node<E> ,包括3個屬性,即Node中封裝的元素item,當前元素的前一個元素引用和後一個元素引用prev/next,和鏈表定義一直,沒什麼新鮮

    private static class Node<E> {        E item;        Node<E> next;        Node<E> prev;        Node(Node<E> prev, E element, Node<E> next) {            this.item = element;            this.next = next;            this.prev = prev;        }    }

2.鏈表的特點是在首尾新增內容比較快捷,所以LinkedList除了實現List介面的add/remove外,還增加了在首尾增加元素的方法addFirst/addList ,removeFirst,removeLast,以及getFirst,getLast擷取首尾元素的方法

3.List介面中得get/remove/add等操作實際上都是操作鏈結表的最末尾


其中我一直想知道的是鏈表中對List介面中得get(index)方法是如何?的,或者說現實容易,有什麼最佳化呢,看了原始碼,發現原來最佳化的內容並沒有我想像的高端,具體是:

 首先,看index位於的鏈表的前一半還是後一半(對size>>1 得出中間數,然後判斷index和size>>1的關係得知)

然後,如果index在鏈表的前半部分,就正向遍曆,如果index在鏈表的後半段,則是從末尾開始遍曆

這是LinkedList中根據給定的索引index擷取元素的實現:

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;        }    }


當打算原始碼的時候,如果其中的大部分內容已經知道個大概了,只有一些細節不清楚,這種狀態下,收穫最大,完全不知道,或者完全知道的時候,看原始碼都沒有什麼意思,這是一直以來我的學習心得。


Java中LinkedList筆記

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.