集合比较
?
?
TreeMap的兩種排序方法
TreeSet可以實現(xiàn)對元素按照某種規(guī)則進行排序
一 自然排序
1.Student類中實現(xiàn) Comparable<T>接口
2.重寫Comparable接口中的Compareto方法
二 比較器排序
1.單獨創(chuàng)建一個比較類,這里以MyComparator為例,并且要讓其繼承Comparator<T>接口
2.重寫Comparator接口中的Compare方法
A:自然排序:要在自定義類中實現(xiàn)Comparerable<T>接口 ,并且重寫compareTo方法
B:比較器排序:在自定義類中實現(xiàn)Comparetor<t>接口,重寫compare方法
TreeMap和HashMap的區(qū)別
1、 HashMap通過hashcode對其內(nèi)容進行快速查找,而TreeMap中所有的元素都保持著某種固定的順序,如果你需要得到一個有序的結(jié)果你就應(yīng)該使用TreeMap(HashMap中元素的排列順序是不固定的)。
2、在Map 中插入、刪除和定位元素,HashMap是最好的選擇。但如果您要按自然順序或自定義順序遍歷鍵,那么TreeMap會更好。使用HashMap要求添加的鍵類明確定義了hashCode()和 equals()的實現(xiàn)。
兩個map中的元素一樣,但順序不一樣,導(dǎo)致hashCode()不一樣。
同樣做測試:
在HashMap中,同樣的值的map,順序不同,equals時,false;
而在treeMap中,同樣的值的map,順序不同,equals時,true,說明,treeMap在equals()時是整理了順序了的。????
HashTable與HashMap
1、同步性:Hashtable是線程安全的,也就是說是同步的,而HashMap是線程序不安全的,不是同步的。
2、HashMap允許存在一個為null的key,多個為null的value 。
3、hashtable的key和value都不允許為null。
Arraylist和Linkedlist
1.ArrayList是實現(xiàn)了基于動態(tài)數(shù)組的數(shù)據(jù)結(jié)構(gòu),LinkedList基于鏈表的數(shù)據(jù)結(jié)構(gòu)。
2.對于隨機訪問get和set,ArrayList覺得優(yōu)于LinkedList,因為LinkedList要移動指針。
3.對于新增和刪除操作add和remove,LinkedList比較占優(yōu)勢,因為ArrayList要移動數(shù)據(jù)。 這一點要看實際情況的。若只對單條數(shù)據(jù)插入或刪除,ArrayList的速度反而優(yōu)于LinkedList。但若是批量隨機的插入刪除數(shù)據(jù),LinkedList的速度大大優(yōu)于ArrayList. 因為ArrayList每插入一條數(shù)據(jù),要移動插入點及之后的所有數(shù)據(jù)。
Vector和ArrayList
1,vector是線程同步的,所以它也是線程安全的,而arraylist是線程異步的,是不安全的。如果不考慮到線程的安全因素,一般用arraylist效率比較高。
2,如果集合中的元素的數(shù)目大于目前集合數(shù)組的長度時,vector增長率為目前數(shù)組長度的100%,而arraylist增長率為目前數(shù)組長度的50%。如果在集合中使用數(shù)據(jù)量比較大的數(shù)據(jù),用vector有一定的優(yōu)勢。
3,如果查找一個指定位置的數(shù)據(jù),vector和arraylist使用的時間是相同的,如果頻繁的訪問數(shù)據(jù),這個時候使用vector和arraylist都可以。而如果移動一個指定位置會導(dǎo)致后面的元素都發(fā)生移動,這個時候就應(yīng)該考慮到使用linklist,因為它移動一個指定位置的數(shù)據(jù)時其它元素不移動。
ArrayList 和Vector是采用數(shù)組方式存儲數(shù)據(jù),此數(shù)組元素數(shù)大于實際存儲的數(shù)據(jù)以便增加和插入元素,都允許直接序號索引元素,但是插入數(shù)據(jù)要涉及到數(shù)組元素移動等內(nèi)存操作,所以索引數(shù)據(jù)快,插入數(shù)據(jù)慢,Vector由于使用了synchronized方法(線程安全)所以性能上比ArrayList要差,LinkedList使用雙向鏈表實現(xiàn)存儲,按序號索引數(shù)據(jù)需要進行向前或向后遍歷,但是插入數(shù)據(jù)時只需要記錄本項的前后項即可,所以插入數(shù)度較快。
?
轉(zhuǎn)載于:https://www.cnblogs.com/RobertLionLin/p/11484113.html
總結(jié)
- 上一篇: 架构测试:HAproxy实现负载均衡,前
- 下一篇: 猫和老鼠服务器维护多久结束,猫和老鼠手游