本篇內(nèi)容介紹了“怎么理解Java中List集合性能”的有關(guān)知識(shí),在實(shí)際案例的操作過程中,不少人都會(huì)遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!
韶關(guān)ssl適用于網(wǎng)站、小程序/APP、API接口等需要進(jìn)行數(shù)據(jù)傳輸應(yīng)用場(chǎng)景,ssl證書未來市場(chǎng)廣闊!成為創(chuàng)新互聯(lián)的ssl證書銷售渠道,可以享受市場(chǎng)價(jià)格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:028-86922220(備注:SSL證書合作)期待與您的合作!List是一個(gè)元素有序,可重復(fù)集合,集合中每個(gè)元素都有其對(duì)應(yīng)的順序索引,List集合允許使用重復(fù)元素,可以通過索引來訪問指定位置的集合元素
var a=new ArrayList(); a.add(new String("zxc")); System.out.println(a.indexOf(new String("zxc")));
這段代碼,程序試圖返回zxc的位置,但實(shí)際上List并未包含該字符串對(duì)象,因?yàn)樵贚ist集合添加時(shí),使用的是new String,但是最后程序依然返回1,這是因?yàn)?,在List中對(duì)比兩個(gè)程序是否相等,只通過equals
在整個(gè)List系列中,ArrayList和LinkedList又是線性表的典型實(shí)現(xiàn):基于數(shù)組的線性表和基于鏈的線性表,Queue代表了隊(duì)列,Deque代表了雙端隊(duì)列
一般來說,由于數(shù)組以一塊連續(xù)內(nèi)存保存所有數(shù)組元素,所以數(shù)組想隨機(jī)訪問時(shí)性能最好,所有的內(nèi)部以數(shù)組作為底層實(shí)現(xiàn)的集合在隨機(jī)訪問時(shí)性能都比較好,而內(nèi)部以鏈表作為底層實(shí)現(xiàn)的集合在執(zhí)行插入,刪除操作時(shí)有較好的性能,但總體來說,ArrayList比linkedList性能要好
在需要遍歷時(shí),對(duì)于ArrayList,Vector,應(yīng)該使用隨機(jī)訪問方法來遍歷,對(duì)于LinkedList,則應(yīng)該使用迭代器Iterator來遍歷
如果需要經(jīng)常執(zhí)行插入,刪除,則LinkedList更好,因?yàn)锳rrayList和Vector需要經(jīng)常出現(xiàn)分配內(nèi)存空間大小
如果有多個(gè)線程同時(shí)訪問List集合中的元素,可以考慮通過Collection將集合包裝成線程安全的集合
“怎么理解Java中List集合性能”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注創(chuàng)新互聯(lián)-成都網(wǎng)站建設(shè)公司網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!