色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

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

通過實例解析Java List正確使用方法

瀏覽:112日期:2022-08-21 15:33:55

List是Java中比較常用的集合類,關于List接口有很多實現類,本文就來簡單介紹下其中幾個重點的實現ArrayList、LinkedList和Vector之間的關系和區別。

List

List 是一個接口,它繼承于Collection的接口。它代表著有序的隊列。當我們討論List的時候,一般都和Set作比較。

List中元素可以重復,并且是有序的(這里的有序指的是按照放入的順序進行存儲。如按照順序把1,2,3存入List,那么,從List中遍歷出來的順序也是1,2,3)。

Set中的元素不可以重復,并且是無序的(從set中遍歷出來的數據和放入順序沒有關系)。

下面是Java中的集合類的關系圖。從中可以大致了解集合類之間的關系

通過實例解析Java List正確使用方法java-collection-hierarchy

ArrayList、 LinkedList 和 Vector之間的區別

從上圖可以看出,ArrayList、 LinkedList 和 Vector都實現了List接口,是List的三種實現,所以在用法上非常相似。他們之間的主要區別體現在不同操作的性能上。后面會詳細分析。

ArrayList

ArrayList底層是用數組實現的,可以認為ArrayList是一個可改變大小的數組。隨著越來越多的元素被添加到ArrayList中,其規模是動態增加的。

LinkedList

LinkedList底層是通過雙向鏈表實現的。所以,LinkedList和ArrayList之前的區別主要就是數組和鏈表的區別。

數組中查詢和賦值比較快,因為可以直接通過數組下標訪問指定位置。

鏈表中刪除和增加比較快,因為可以直接通過修改鏈表的指針(Java中并無指針,這里可以簡單理解為指針。其實是通過Node節點中的變量指定)進行元素的增刪。

所以,LinkedList和ArrayList相比,增刪的速度較快。但是查詢和修改值的速度較慢。同時,LinkedList還實現了Queue接口,所以他還提供了offer(), peek(), poll()等方法。

Vector

Vector和ArrayList一樣,都是通過數組實現的,但是Vector是線程安全的。和ArrayList相比,其中的很多方法都通過同步(synchronized)處理來保證線程安全。

如果你的程序不涉及到線程安全問題,那么使用ArrayList是更好的選擇(因為Vector使用synchronized,必然會影響效率)。

二者之間還有一個區別,就是擴容策略不一樣。在List被第一次創建的時候,會有一個初始大小,隨著不斷向List中增加元素,當List認為容量不夠的時候就會進行擴容。Vector缺省情況下自動增長原來一倍的數組長度,ArrayList增長原來的50%。

ArrayList 和 LinkedList的性能對比

使用以下代碼對ArrayList和LinkedList中的幾種主要操作所用時間進行對比:

ArrayList<Integer> arrayList = new ArrayList<Integer>();LinkedList<Integer> linkedList = new LinkedList<Integer>();// ArrayList addlong startTime = System.nanoTime();for (int i = 0; i < 100000; i++) { arrayList.add(i);}long endTime = System.nanoTime();long duration = endTime - startTime;System.out.println('ArrayList add: ' + duration);// LinkedList addstartTime = System.nanoTime();for (int i = 0; i < 100000; i++) { linkedList.add(i);}endTime = System.nanoTime();duration = endTime - startTime;System.out.println('LinkedList add: ' + duration);// ArrayList getstartTime = System.nanoTime();for (int i = 0; i < 10000; i++) { arrayList.get(i);}endTime = System.nanoTime();duration = endTime - startTime;System.out.println('ArrayList get: ' + duration);// LinkedList getstartTime = System.nanoTime();for (int i = 0; i < 10000; i++) { linkedList.get(i);}endTime = System.nanoTime();duration = endTime - startTime;System.out.println('LinkedList get: ' + duration);// ArrayList removestartTime = System.nanoTime();for (int i = 9999; i >=0; i--) { arrayList.remove(i);}endTime = System.nanoTime();duration = endTime - startTime;System.out.println('ArrayList remove: ' + duration);// LinkedList removestartTime = System.nanoTime();for (int i = 9999; i >=0; i--) { linkedList.remove(i);}endTime = System.nanoTime();duration = endTime - startTime;System.out.println('LinkedList remove: ' + duration);

結果:

ArrayList add: 13265642LinkedList add: 9550057ArrayList get: 1543352LinkedList get: 85085551ArrayList remove: 199961301LinkedList remove: 85768810arraylist-vs-linkedlist1

通過實例解析Java List正確使用方法

他們的表現的差異是顯而易見的。在添加和刪除操作上LinkedList更快,但在查詢速度較慢。

如何選擇

如果涉及到多線程,那么就選擇Vector(當然,你也可以使用ArrayList并自己實現同步)。

如果不涉及到多線程就從LinkedList、ArrayList中選。 LinkedList更適合從中間插入或者刪除(鏈表的特性)。 ArrayList更適合檢索和在末尾插入或刪除(數組的特性)。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Java
相關文章:
主站蜘蛛池模板: 亚州毛片 | 国产成人夜间影院在线观看 | 毛片69| 国产成人精品日本亚洲网址 | 国产精品免费久久 | 日韩a级一片 | 免费一级毛片在线播放视频 | 步兵社区| 天天干夜夜怕 | 久久99亚洲精品久久 | 亚洲综合精品 | 国产美女精品在线 | 男女视频免费在线观看 | 性做久久久久免费看 | 九九国产在线 | 毛片一级 | 盗摄偷拍a在线观看 | 欧美成人免费午夜全 | 国产精品日本欧美一区二区 | 精品亚洲永久免费精品 | 本道久久综合88全国最大色 | 日韩专区亚洲国产精品 | 国产v综合v亚洲欧美大另类 | 久久视频免费观看 | 欧美日韩高清不卡免费观看 | 武松金莲肉体交战在线观看 | 97超级碰碰碰免费公开在线观看 | 在线不卡一区二区三区日韩 | 美女脱了内裤张开腿让男人桶网站 | 天干天干天啪啪夜爽爽色 | a级精品九九九大片免费看 a级毛片免费观看网站 | 五月天激激婷婷大综合蜜芽 | 精品视频在线免费看 | 亚州一级毛片 | 免费观看成人久久网免费观看 | 国产高清一区二区三区视频 | 性色tv| 色偷偷88欧美精品久久久 | 欧美成一级 | 美女黄色一级片 | 精品极品三级久久久久 |