這期內(nèi)容當(dāng)中小編將會(huì)給大家?guī)碛嘘P(guān)java中常用集合的使用方法,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
沙依巴克網(wǎng)站建設(shè)公司創(chuàng)新互聯(lián)公司,沙依巴克網(wǎng)站設(shè)計(jì)制作,有大型網(wǎng)站制作公司豐富經(jīng)驗(yàn)。已為沙依巴克近1000家提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\成都外貿(mào)網(wǎng)站制作要多少錢,請(qǐng)找那個(gè)售后服務(wù)好的沙依巴克做網(wǎng)站的公司定做!
在java中集合主要分為:List,Set,Map三種,其中List與Set是繼承自Collection,而Map不是。
List與Set的區(qū)別:List中的元素有存放順序,并且可以存放重復(fù)元素,檢索效率高,插入刪除效率低,Set沒有存放順序,而且不可以存放重復(fù)元素,后來的元素會(huì)把前面重復(fù)的元素替換掉,檢索效率低,插入刪除效率高。(Set存儲(chǔ)位置是由它的HashCode碼決定的,所以它存儲(chǔ)的對(duì)象必須有equals()方法,而且Set遍歷只能用迭代,因?yàn)樗鼪]有下標(biāo)。)
1、最常用的集合:ArrayList
特點(diǎn):ArrayList集合中元素存儲(chǔ)的位置是連續(xù)的,所以查詢起來會(huì)比較快捷,但是執(zhí)行插入刪除操作會(huì)比較麻煩一點(diǎn),會(huì)引起其他元素位置的變化。
注意:list中存儲(chǔ)的是對(duì)象的引用,而不是對(duì)象本身。如果不清楚這一點(diǎn)會(huì)在這里有個(gè)坑,例如:
有人為了節(jié)省優(yōu)化代碼,節(jié)省虛擬機(jī)內(nèi)存會(huì)這么寫代碼:
List> list=new ArrayList<>(); List
list2=new ArrayList<>(); for(int i=0;i<10;i++){ list2.add(""+i); list.add(list2); list2.clear(); }
這樣寫雖然可以一個(gè)對(duì)象重復(fù)使用,但是,list存儲(chǔ)的是對(duì)象的引用,當(dāng)list2.clear();的時(shí)候,list中的list2也會(huì)clear,這樣最后得到的就只能是一堆空的集合了。
2、與最常用集合相反的集合:LinkedList
LinkedList與ArrayList是互補(bǔ)的,所以ArrayList的優(yōu)點(diǎn)就是LinkedList的缺點(diǎn),ArrayList的缺點(diǎn)就是LinkedList的優(yōu)點(diǎn)。
特點(diǎn):LinkedList中元素位置是任意的,所以執(zhí)行插入刪除操作效率較高,查詢效率較低。
3、與一般集合都相反的集合:Vector
為什么說它與一般集合都相反呢?因?yàn)樗且环N老的動(dòng)態(tài)數(shù)組,很多方法都用synchonized修飾,所以它是線程安全得,而一般集合是線程不安全得。
特點(diǎn):多個(gè)線程同時(shí)訪問不會(huì)發(fā)生不確定的結(jié)果,但是它的效率會(huì)比較低,如果要考慮線程安全的話可以用它。
4、Set中最常用的集合:HashSet
在用Set集合的時(shí)候我?guī)缀跤玫亩际荋ashSet,HashSet是使用Hash表實(shí)現(xiàn)的,集合里面的元素是無序得,可以有null值,但是不能有重復(fù)元素。
特點(diǎn):因?yàn)橄嗤脑鼐哂邢嗤膆ashCode,所以不能有重復(fù)元素
5、Set中第二常用的集合:TreeSet
TreeSet是用二叉樹結(jié)構(gòu)實(shí)現(xiàn)的集合
特點(diǎn):集合中的元素是有順序得,不允許放入null,同樣不能放入重復(fù)元素。
6、第二常用的集合:HashMap
經(jīng)常遇到需要使用鍵值對(duì)存儲(chǔ)的場(chǎng)景,而HashMap是用得最多的一種鍵值對(duì)存儲(chǔ)的集合。
特點(diǎn):HashMap允許空鍵值,并且它是非線程安全的,所以插入、刪除和定位元素會(huì)比較快。
7、一些不太常用的Map集合:TreeMap,HashTable
TreeMap是基于紅黑樹實(shí)現(xiàn)的,適用于按自然順序火茲定于順序遍歷key。
HashTable是基于HashCode實(shí)現(xiàn)的,但它是線程安全的,所以會(huì)比HashMap效率低,而且不允許null值。
上述就是小編為大家分享的java中常用集合的使用方法了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。