java中Vector->ArrayList、Hashtable->HashMap

某些高級IDE在檢測代碼成熟問題時,會報告集合是否過時的問題。目前過時的集合類有兩個java.util.Vector 和 java.util.Hashtable 。

Vector的api描述是:從jdk 1.2版本開始,該類被修正爲實現List接口,併成爲Java Collection集合框架的一員,區別於其他一些新的集合實現類,Vector是線程安全的。如果是一個線程安全的實現,推薦使用ArrayList代替Vector。

Hashtable的api描述是:從jdk 1.2版本開始,該類被修正爲實現List接口,併成爲Java Collection集合框架的一員,區別於其他一些新的集合實現類,Hashtable是線程安全的。如果是一個線程安全的實現,推薦使用HashMap代替Hashtable。如果是高併發的線程安全的實現,推薦使用ConcurrentHashMap代替Hashtable。

Vector和ArrayList區別  
       Vector和ArrayList Vector和ArrayList在使用上非常相似,都可用來表示一組數量可變的對象應用的集合,並且可以隨機地訪問其中的元素。   
       Vector的方法都是同步的(Synchronized),是線程安全的(thread-safe),而ArrayList的方法不是,由於線程的同步必然要影響性能,因此,ArrayList的性能比Vector好。  
       當Vector或ArrayList中的元素超過它的初始大小時,Vector會將它的容量翻倍,而ArrayList只增加50%的大小,這樣,ArrayList就有利於節約內存空間。



Hashtable和HashMap區別 
Hashtable和HashMap它們的性能方面的比較類似 Vector和ArrayList,比如Hashtable的方法是同步的,而HashMap的不是。
  
ArrayList和LinkedList區別 
對於處理一列數據項,Java提供了兩個類ArrayList和LinkedList,ArrayList的內部實現是基於內部數組Object[],所以從概念上講,它更象數組,但LinkedList的內部實現是基於一組連接的記錄,所以,它更象一個鏈表結構,所以,它們在性能上有很大的差別。   
從上面的分析可知,在ArrayList的前面或中間插入數據時,你必須將其後的所有數據相應的後移,這樣必然要花費較多時間,所以,當你的操作是在一列數據的後面添加數據而不是在前面或中間,並且需要隨機地訪問其中的元素時,使用ArrayList會提供比較好的性能  
而訪問鏈表中的某個元素時,就必須從鏈表的一端開始沿着連接方向一個一個元素地去查找,直到找到所需的元素爲止,所以,當你的操作是在一列數據的前面或中間添加或刪除數據,並且按照順序訪問其中的元素時,就應該使用LinkedList了。   
如果在編程中,1,2兩種情形交替出現,這時,你可以考慮使用List這樣的通用接口,而不用關心具體的實現,在具體的情形下,它的性能由具體的實現來保證。

配置集合類的初始大小   
在Java集合框架中的大部分類的大小是可以隨着元素個數的增加而相應的增加的,我們似乎不用關心它的初始大小,但如果我們考慮類的性能問題時,就一定要考慮儘可能地設置好集合對象的初始大小,這將大大提高代碼的性能。 
比如,Hashtable缺省的初始大小爲101,載入因子爲0.75,即如果其中的元素個數超過75個,它就必須增加大小並重新組織元素,所以,如果你知道在創建一個新的Hashtable對象時就知道元素的確切數目如爲110,那麼,就應將其初始大小設爲110/0.75=148,這樣,就可以避免重新組織內存並增加大小。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章