Java集合

Java中的集合有兩類:一類是Collection接口集合,實(shí)現(xiàn)有List和Set;還有一類是Map接口集合,實(shí)現(xiàn)有Hashmap、Hashtable等。

  1. List存儲(chǔ)元素是有序、可重復(fù)的,實(shí)現(xiàn)包括ArrayList、LinkedList等;
  2. Set是無序、不可重復(fù)的,實(shí)現(xiàn)有HashSet、TreeSet(二叉排序樹);
  3. Map是鍵值對(duì)存儲(chǔ),不能包含重復(fù)的key,能包含重復(fù)的value,實(shí)現(xiàn)包括有:Hashtable、HashMap、Treemap(二叉排序樹)。

Map集合實(shí)現(xiàn)類:

HashMap:
HashMap是鏈表加數(shù)組實(shí)現(xiàn)的,鏈表[],數(shù)組當(dāng)桶,桶中存鏈表,鏈表里面是元素。來了新元素,存儲(chǔ)到首部。
因?yàn)殒I對(duì)象不可以重復(fù),所以HashMap最多只允許一條記錄的鍵為Null,允許多條記錄的值為Null,是非同步的。

Hashtable:
是HashMap的線程安全版,它支持線程的同步,即任一時(shí)刻只有一個(gè)線程能寫Hashtable,因此也導(dǎo)致了Hashtale在寫入時(shí)會(huì)比較慢,它繼承自Dictionary類,不同的是它不允許記錄的鍵或者值為null,同時(shí)效率較低。

LinkedHashMap:
LinkedHashMap保存了記錄的插入順序,在用Iteraor遍歷LinkedHashMap時(shí),先得到的記錄肯定是先插入的,在遍歷的時(shí)候會(huì)比HashMap慢,有HashMap的全部特性。

TreeMap:
TreeMap實(shí)現(xiàn)SortMap接口,能夠把它保存的記錄根據(jù)鍵排序,默認(rèn)是按鍵值的升序排序(自然順序),也可以指定排序的比較器,當(dāng)用Iterator遍歷TreeMap時(shí),得到的記錄是排過序的。不允許key值為空,非同步的。

主要實(shí)現(xiàn)類區(qū)別小結(jié):

1. Vector和ArrayList

1,vector是線程同步的,所以它也是線程安全的,而arraylist是線程異步的,是不安全的。如果不考慮到線程的安全因素,一般用arraylist效率比較高。
2,如果集合中的元素的數(shù)目大于目前集合數(shù)組的長(zhǎng)度時(shí),vector增長(zhǎng)率為目前數(shù)組長(zhǎng)度的100%,而arraylist增長(zhǎng)率為目前數(shù)組長(zhǎng)度的50%。如果在集合中使用數(shù)據(jù)量比較大的數(shù)據(jù),用vector有一定的優(yōu)勢(shì)。
3,如果查找一個(gè)指定位置的數(shù)據(jù),vector和arraylist使用的時(shí)間是相同的,如果頻繁的訪問數(shù)據(jù),這個(gè)時(shí)候使用vector和arraylist都可以。而如果移動(dòng)一個(gè)指定位置會(huì)導(dǎo)致后面的元素都發(fā)生移動(dòng),這個(gè)時(shí)候就應(yīng)該考慮到使用linklist,因?yàn)樗苿?dòng)一個(gè)指定位置的數(shù)據(jù)時(shí)其它元素不移動(dòng)。
ArrayList 和Vector是采用數(shù)組方式存儲(chǔ)數(shù)據(jù),此數(shù)組元素?cái)?shù)大于實(shí)際存儲(chǔ)的數(shù)據(jù)以便增加和插入元素,都允許直接序號(hào)索引元素,但是插入數(shù)據(jù)要涉及到數(shù)組元素移動(dòng)等內(nèi)存操作,所以索引數(shù)據(jù)快,插入數(shù)據(jù)慢,Vector由于使用了synchronized方法(線程安全)所以性能上比ArrayList要差,LinkedList使用雙向鏈表實(shí)現(xiàn)存儲(chǔ),按序號(hào)索引數(shù)據(jù)需要進(jìn)行向前或向后遍歷,但是插入數(shù)據(jù)時(shí)只需要記錄本項(xiàng)的前后項(xiàng)即可,所以插入數(shù)度較快。

2. ArrayList 和LinkedList

1.ArrayList是實(shí)現(xiàn)了基于動(dòng)態(tài)數(shù)組的數(shù)據(jù)結(jié)構(gòu),LinkedList基于鏈表的數(shù)據(jù)結(jié)構(gòu)。
2.對(duì)于隨機(jī)訪問get和set,ArrayList覺得優(yōu)于LinkedList,因?yàn)長(zhǎng)inkedList要移動(dòng)指針。
3.對(duì)于新增和刪除操作add和remove,LinedList比較占優(yōu)勢(shì),因?yàn)锳rrayList要移動(dòng)數(shù)據(jù)。 這一點(diǎn)要看實(shí)際情況的。若只對(duì)單條數(shù)據(jù)插入或刪除,ArrayList的速度反而優(yōu)于LinkedList。但若是批量隨機(jī)的插入刪除數(shù)據(jù),LinkedList的速度大大優(yōu)于ArrayList. 因?yàn)锳rrayList每插入一條數(shù)據(jù),要移動(dòng)插入點(diǎn)及之后的所有數(shù)據(jù)。

3. HashMap與TreeMap

1、 HashMap通過hashcode對(duì)其內(nèi)容進(jìn)行快速查找,而TreeMap中所有的元素都保持著某種固定的順序,如果你需要得到一個(gè)有序的結(jié)果你就應(yīng)該使用TreeMap(HashMap中元素的排列順序是不固定的)。
2、在Map 中插入、刪除和定位元素,HashMap是最好的選擇。但如果您要按自然順序或自定義順序遍歷鍵,那么TreeMap會(huì)更好。使用HashMap要求添加的鍵類明確定義了hashCode()和 equals()的實(shí)現(xiàn)。
兩個(gè)map中的元素一樣,但順序不一樣,導(dǎo)致hashCode()不一樣。
同樣做測(cè)試:
在HashMap中,同樣的值的map,順序不同,equals時(shí),false;
而在treeMap中,同樣的值的map,順序不同,equals時(shí),true,說明,treeMap在equals()時(shí)是整理了順序了的。

4. HashTable與HashMap

1、同步性:Hashtable是線程安全的,也就是說是同步的,而HashMap是線程序不安全的,不是同步的。
2、HashMap允許存在一個(gè)為null的key,多個(gè)為null的value 。
3、hashtable的key和value都不允許為null。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容