日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Java中LinkedList真的是查找慢增刪快

瀏覽:30日期:2022-08-22 13:27:03

測試結果

廢話不多說,先上測試結果。作者分別在ArrayList和LinkedList的頭部、尾部和中間三個位置插入與查找100000個元素所消耗的時間來進行對比測試,下面是測試結果

(感謝@Hosalo的指正,在這里說明一下測試的環(huán)境,尾部插入是在空表的基礎上測試的,頭部和中間位置插入是在已存在100000個元素的表上進行測試的)

插入 查找 ArrayList尾部 26ms 4ms ArrayList頭部 2887ms 3ms ArrayList中間 1936ms 4ms LinkedList尾部 28ms 9ms LinkedList頭部 15ms 11ms LinkedList中間 12310ms 11387ms

測試結論

ArrayList的查找性能絕對是一流的,無論查詢的是哪個位置的元素 ArrayList除了尾部插入的性能較好外(位置越靠后性能越好),其他位置性能就不如人意了 LinkedList在頭尾查找、插入性能都是很棒的,但是在中間位置進行操作的話,性能就差很遠了,而且跟ArrayList完全不是一個量級的

源碼分析

我們把Java中的ArrayList和LinkedList就是分別對順序表和雙向鏈表的一種實現,所以在進行源碼分析之前,我們先來簡單回顧一下數據結構中的順序表與雙向鏈表中的關鍵概念

順序表:需要申請連續(xù)的內存空間保存元素,可以通過內存中的物理位置直接找到元素的邏輯位置。在順序表中間插入or刪除元素需要把該元素之后的所有元素向前or向后移動。 雙向鏈表:不需要申請連續(xù)的內存空間保存元素,需要通過元素的頭尾指針找到前繼與后繼元素(查找元素的時候需要從頭or尾開始遍歷整個鏈表,直到找到目標元素)。在雙向鏈表中插入or刪除元素不需要移動元素,只需要改變相關元素的頭尾指針即可。

所以我們潛意識會認為:ArrayList查找快,增刪慢。LinkedList查找慢,增刪快。但實際上真的是這樣的嗎?我們一起來看看吧。

測試程序

測試程序代碼基本沒有什么營養(yǎng),這里就不貼出來了,但是得把程序的運行結果貼出來,方便逐個分析。

運行結果

ArrayList尾部插入100000個元素耗時:26msLinkedList尾部插入100000個元素耗時:28msArrayList頭部插入100000個元素耗時:859msLinkedList頭部插入100000個元素耗時:15msArrayList中間插入100000個元素耗時:1848msLinkedList中間插入100000個元素耗時:15981msArrayList頭部讀取100000個元素耗時:7msLinkedList頭部讀取100000個元素耗時:11msArrayList尾部讀取100000個元素耗時:12msLinkedList尾部讀取100000個元素耗時:9msArrayList中間讀取100000個元素耗時:13msLinkedList中間讀取100000個元素耗時:11387ms

ArrayList尾部插入

源碼

add(E e)方法 public boolean add(E e) { // 檢查是否需要擴容 ensureCapacityInternal(size + 1); // Increments modCount!! // 直接在尾部添加元素 elementData[size++] = e; return true; }

可以看出,對ArrayList的尾部插入,直接插入即可,無須額外的操作。

LinkedList尾部插入

源碼

LinkedList中定義了頭尾節(jié)點 /** * Pointer to first node. */ transient Node<E> first; /** * Pointer to last node. */ transient Node<E> last;

add(E e)方法,該方法中調用了linkLast(E e)方法

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

linkLast(E e)方法,可以看出,在尾部插入的時候,并不需要從頭開始遍歷整個鏈表,因為已經事先保存了尾結點,所以可以直接在尾結點后面插入元素

/** * Links e as last element. */ void linkLast(E e) { // 先把原來的尾結點保存下來 final Node<E> l = last; // 創(chuàng)建一個新的結點,其頭結點指向last final Node<E> newNode = new Node<>(l, e, null); // 尾結點置為newNode last = newNode; if (l == null) first = newNode; else // 修改原先的尾結點的尾結點,使其指向新的尾結點 l.next = newNode; size++; modCount++; }

總結

對于尾部插入而言,ArrayList與LinkedList的性能幾乎是一致的

ArrayList頭部插入

源碼

add(int index, E element)方法,可以看到通過調用系統(tǒng)的數組復制方法來實現了元素的移動。所以,插入的位置越靠前,需要移動的元素就會越多

public void add(int index, E element) { rangeCheckForAdd(index); ensureCapacityInternal(size + 1); // Increments modCount!! // 把原來數組中的index位置開始的元素全部復制到index+1開始的位置(其實就是index后面的元素向后移動一位) System.arraycopy(elementData, index, elementData, index + 1, size - index); // 插入元素 elementData[index] = element; size++; }

LinkedList頭部插入

源碼

add(int index, E element)方法,該方法先判斷是否是在尾部插入,如果是調用linkLast()方法,否則調用linkBefore(),那么是否真的就是需要重頭開始遍歷呢?我們一起來看看

public void add(int index, E element) { checkPositionIndex(index); if (index == size) linkLast(element); else linkBefore(element, node(index)); }

在頭尾以外的位置插入元素當然得找出這個位置在哪里,這里面的node()方法就是關鍵所在,這個函數的作用就是根據索引查找元素,但是它會先判斷index的位置,如果index比size的一半(size >> 1,右移運算,相當于除以2)要小,就從頭開始遍歷。否則,從尾部開始遍歷。從而可以知道,對于LinkedList來說,操作的元素的位置越往中間靠攏,效率就越低

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

這個函數的工作就只是負責把元素插入到相應的位置而已,關鍵的工作在node()方法中已經完成了

void linkBefore(E e, Node<E> succ) { // assert succ != null; final Node<E> pred = succ.prev; final Node<E> newNode = new Node<>(pred, e, succ); succ.prev = newNode; if (pred == null) first = newNode; else pred.next = newNode; size++; modCount++; }

總結

對于LinkedList來說,頭部插入和尾部插入時間復雜度都是O(1) 但是對于ArrayList來說,頭部的每一次插入都需要移動size-1個元素,效率可想而知 但是如果都是在最中間的位置插入的話,ArrayList速度比LinkedList的速度快將近10倍

ArrayList、LinkedList查找

這就沒啥好說的了,對于ArrayList,無論什么位置,都是直接通過索引定位到元素,時間復雜度O(1) 而對于LinkedList查找,其核心方法就是上面所說的node()方法,所以頭尾查找速度極快,越往中間靠攏效率越低

到此這篇關于Java中LinkedList真的是查找慢增刪快 的文章就介紹到這了,更多相關Java LinkedList查找慢增刪快 內容請搜索好吧啦網以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Java
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
久久国产乱子精品免费女| 亚洲欧美久久| 国产不卡人人| 你懂的国产精品| 亚洲欧洲日韩精品在线| 中文字幕亚洲影视| 老牛国产精品一区的观看方式| 免播放器亚洲一区| 亚洲精品欧美| 欧美午夜三级| 精品国产欧美| 高潮一区二区| 视频在线观看一区| 在线一区欧美| 亚洲精选久久| 日韩一区精品字幕| 日韩中文av| 精品久久在线| 好吊一区二区三区| av一区在线| re久久精品视频| 亚洲一区二区三区中文字幕在线观看 | 午夜精品福利影院| 影院欧美亚洲| 男女男精品网站| 麻豆视频久久| 日本免费一区二区三区四区| 日韩在线卡一卡二| 日韩av电影一区| 精品三级国产| 欧美三级精品| 免费成人性网站| 国产美女精品视频免费播放软件| 国产精品1区| 国产传媒在线观看| 中文字幕日本一区二区| 日韩欧美中文| 免费日本视频一区| 国产在线看片免费视频在线观看| 丝瓜av网站精品一区二区| 成人污污视频| 在线午夜精品| 日韩久久视频| 久久一区精品| 9色精品在线| 日韩欧美自拍| 国产精品红桃| 国产精品调教| 99精品综合| 国产夫妻在线| 色老板在线视频一区二区| 国产日韩精品视频一区二区三区| 亚洲欧洲日韩| 日韩精品久久久久久| 亚洲精品极品| 水蜜桃精品av一区二区| 精品三级久久| 伊人久久av| 久久精品国产亚洲夜色av网站| 午夜久久tv| 日韩欧美精品一区二区综合视频| 综合亚洲自拍| 国产欧美午夜| 国产亚洲欧美日韩精品一区二区三区 | 激情久久一区二区| 亚洲免费网址| 日产欧产美韩系列久久99| 国产精品美女在线观看直播| 国产精品一站二站| 国产精品115| 亚洲精品网址| 日本色综合中文字幕| 国产精品观看| 国产视频一区欧美| 国产精品一区二区免费福利视频| 久久久国产亚洲精品| 婷婷五月色综合香五月| 日韩电影免费网站| 亚洲永久精品唐人导航网址| 国产精品视频首页| 亚洲国产日韩欧美在线| 欧美日韩夜夜| 国产精品av一区二区| 蜜桃av一区二区| 国产精品扒开腿做爽爽爽软件| 久久久天天操| 日本成人手机在线| 伊人精品在线| 91视频一区| 国产欧美一区二区精品久久久 | 综合激情在线| 精品国产欧美日韩| 亚洲毛片在线免费| 久久精品国产亚洲夜色av网站 | 日韩中文av| 久久免费大视频| 欧美黄色精品| 日本少妇一区二区| 午夜精品婷婷| av高清一区| 精品女同一区二区三区在线观看| 久久九九精品| 成人精品动漫一区二区三区| 日韩精品一区二区三区免费视频 | 久久精品免费一区二区三区| 日韩网站在线| 日本免费新一区视频| 日韩一区二区在线免费| 亚洲精品乱码| 欧美日韩国产免费观看视频| 日韩一区二区三区免费视频| 亚洲午夜精品久久久久久app| 欧美a在线观看| 久久精品网址| 欧美韩日一区| 欧美成人基地 | 亚洲欧美日本视频在线观看| 精品视频久久| 国产aⅴ精品一区二区三区久久| 精品视频高潮| 国产精品三级| 久久字幕精品一区| 麻豆91精品视频| 国产精品日韩精品在线播放 | 欧美另类综合| 一区在线观看| 日韩区一区二| 国产精品66| 97精品一区二区| 久久久9色精品国产一区二区三区| 日韩成人免费| 狠狠色狠狠色综合日日tαg| 蜜桃一区二区三区在线| 一区久久精品| 日韩av黄色在线| 久久久国产亚洲精品| 久久99精品久久久久久园产越南 | 美女久久久久久| 免费中文字幕日韩欧美| 日本中文字幕视频一区| 欧美1区2区3| 午夜精品成人av| 日韩欧美午夜| 97成人在线| 日本aⅴ免费视频一区二区三区| 亚洲无线观看| 日韩在线一区二区| 免费成人网www| 理论片午夜视频在线观看| 欧美黄色网页| 久久久五月天| 欧美在线亚洲| 免费视频久久| 乱一区二区av| 男女精品网站| av在线日韩| 麻豆精品新av中文字幕| 欧美一级专区| 久久国产小视频| 老司机精品视频网| 69堂免费精品视频在线播放| 日本一区二区三区视频在线看| 国精品一区二区| 午夜天堂精品久久久久| 免费看欧美美女黄的网站| 亚洲精品在线观看91| 日本精品影院| 日韩一区二区三区免费播放| 蜜桃精品在线| 免费一级欧美片在线观看网站 | 国产一区二区三区四区五区| 亚洲成人精品| 91伊人久久| 亚洲小说春色综合另类电影| 91精品二区| 蜜桃一区二区三区在线| 国产精品亲子伦av一区二区三区 | 精品国产不卡一区二区| 美女国产一区| 亚洲三级网址| 欧美日韩夜夜| 久久精品国产在热久久| 综合激情视频| 影音先锋国产精品| 日本综合视频| 成人精品国产亚洲| 亚洲国产专区| 青草久久视频| 亚洲欧洲美洲av| 日韩视频一区| 日韩精品视频一区二区三区| 免费日韩成人| 久久字幕精品一区| 精品九九久久| 久久亚洲资源中文字| 国产日韩一区二区三区在线播放 | 久久精品一本| 精品国产三区在线| 99视频精品全国免费| 一区二区国产在线|