欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2020年11月03日 14:25:38   作者:Hollis在51CTO  
這篇文章主要介紹了通過實例解析Java List正確使用方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下

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

List

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

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

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

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


java-collection-hierarchy

ArrayList、 LinkedList 和 Vector之間的區(qū)別

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

ArrayList

ArrayList底層是用數(shù)組實現(xiàn)的,可以認(rèn)為ArrayList是一個可改變大小的數(shù)組。隨著越來越多的元素被添加到ArrayList中,其規(guī)模是動態(tài)增加的。

LinkedList

LinkedList底層是通過雙向鏈表實現(xiàn)的。所以,LinkedList和ArrayList之前的區(qū)別主要就是數(shù)組和鏈表的區(qū)別。

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

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

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

Vector

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

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

二者之間還有一個區(qū)別,就是擴(kuò)容策略不一樣。在List被第一次創(chuàng)建的時候,會有一個初始大小,隨著不斷向List中增加元素,當(dāng)List認(rèn)為容量不夠的時候就會進(jìn)行擴(kuò)容。Vector缺省情況下自動增長原來一倍的數(shù)組長度,ArrayList增長原來的50%。

ArrayList 和 LinkedList的性能對比

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

ArrayList<Integer> arrayList = new ArrayList<Integer>();
LinkedList<Integer> linkedList = new LinkedList<Integer>();

// ArrayList add
long 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 add
startTime = 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 get
startTime = 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 get
startTime = 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 remove
startTime = 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 remove
startTime = System.nanoTime();

for (int i = 9999; i >=0; i--) {
  linkedList.remove(i);
}
endTime = System.nanoTime();
duration = endTime - startTime;
System.out.println("LinkedList remove: " + duration);

結(jié)果:

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


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

如何選擇

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

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

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Slf4j+logback實現(xiàn)JSON格式日志輸出方式

    Slf4j+logback實現(xiàn)JSON格式日志輸出方式

    這篇文章主要介紹了Slf4j+logback實現(xiàn)JSON格式日志輸出方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-12-12
  • JSR303校驗前端傳遞的數(shù)據(jù)方式

    JSR303校驗前端傳遞的數(shù)據(jù)方式

    這篇文章主要介紹了JSR303校驗前端傳遞的數(shù)據(jù)方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • Java線程池的應(yīng)用實例分析

    Java線程池的應(yīng)用實例分析

    這篇文章主要介紹了Java線程池的應(yīng)用,結(jié)合具體實例形式分析了java線程池的斐波那契數(shù)列計算與模擬工人做工等應(yīng)用的操作技巧,需要的朋友可以參考下
    2019-10-10
  • 解決elastic-job-ui在使用druid作為數(shù)據(jù)庫連接池時作業(yè)維度報錯問題

    解決elastic-job-ui在使用druid作為數(shù)據(jù)庫連接池時作業(yè)維度報錯問題

    這篇文章主要介紹了解決elastic-job-ui在使用druid作為數(shù)據(jù)庫連接池時作業(yè)維度報錯問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • 詳細(xì)解讀Hibernate的緩存機(jī)制

    詳細(xì)解讀Hibernate的緩存機(jī)制

    這篇文章主要介紹了詳細(xì)解讀Hibernate的緩存機(jī)制,具有一定參考價值,這里分享給大家,供大家學(xué)習(xí)參閱。
    2017-10-10
  • IDEA的.idea文件夾和iml文件使用方式

    IDEA的.idea文件夾和iml文件使用方式

    這篇文章主要介紹了IDEA的.idea文件夾和iml文件使用方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • JAVA swing布局管理器實例解析

    JAVA swing布局管理器實例解析

    這篇文章主要介紹了JAVA swing布局管理器實例解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-03-03
  • JavaWeb文件上傳與下載功能解析

    JavaWeb文件上傳與下載功能解析

    這篇文章主要為大家詳細(xì)介紹了JavaWeb文件上傳與下載功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-06-06
  • JSch教程使用sftp協(xié)議實現(xiàn)服務(wù)器文件載操作

    JSch教程使用sftp協(xié)議實現(xiàn)服務(wù)器文件載操作

    這篇文章主要為大家介紹了JSch如何使用sftp協(xié)議實現(xiàn)服務(wù)器文件上傳下載操作,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步
    2022-03-03
  • MyBatis實現(xiàn)多表聯(lián)查的詳細(xì)代碼

    MyBatis實現(xiàn)多表聯(lián)查的詳細(xì)代碼

    這篇文章主要介紹了MyBatis如何實現(xiàn)多表聯(lián)查,通過實例代碼給大家介紹使用映射配置文件實現(xiàn)多表聯(lián)查,使用注解的方式實現(xiàn)多表聯(lián)查,需要的朋友可以參考下
    2022-08-08

最新評論