HashMap和Hashtable的區別
HashMap和HashTable的比較是Java面試中的常見問題,用來考驗程式設計師是否能夠正確使用集合類以及是否可以隨機應變使用多種思路解決問題。HashMap的工作原理、ArrayList與Vector的比較以及這個問題是有關Java 集合框架的最經典的問題。HashTable是個過時的集合類,存在於Java API中很久了。在Java 4中被重寫了,實現了Map介面,所以自此以後也成了Java集合框架中的一部分。HashTable和HashMap在Java面試中相當容易被問到,甚至成為了集合框架面試題中最常被考的問題,所以在參加任何Java面試之前,都不要忘了準備這一題。
這篇文章中,我們不僅將會看到HashMap和HashTable的區別,還將看到它們之間的相似之處。
HashMap和HashTable的區別
HashMap和HashTable都實現了Map介面,但決定用哪一個之前先要弄清楚它們之間的分別。主要的區別有:執行緒安全性,同步(synchronization),以及速度。
- HashMap幾乎可以等價於HashTable,除了HashMap是非synchronized的,並可以接受null(HashMap可以接受為null的鍵值(key)和值(value),而HashTable則不行)。
- HashMap是非synchronized,而HashTable是synchronized,這意味著HashTable是執行緒安全的,多個執行緒可以共享一個HashTable;而如果沒有正確的同步的話,多個執行緒是不能共享HashMap的。Java 5提供了ConcurrentHashMap,它是HashTable的替代,比HashTable的擴充套件性更好。
- 另一個區別是HashMap的迭代器(Iterator)是fail-fast迭代器,而HashTable的enumerator迭代器不是fail-fast的。所以當有其它執行緒改變了HashMap的結構(增加或者移除元素),將會丟擲ConcurrentModificationException,但迭代器本身的remove()方法移除元素則不會丟擲ConcurrentModificationException異常。但這並不是一個一定發生的行為,要看JVM。這條同樣也是Enumeration和Iterator的區別。
- 由於HashTable是執行緒安全的也是synchronized,所以在單執行緒環境下它比HashMap要慢。如果你不需要同步,只需要單一執行緒,那麼使用HashMap效能要好過HashTable。
- HashMap不能保證隨著時間的推移Map中的元素次序是不變的。
要注意的一些重要術語:
1) sychronized意味著在一次僅有一個執行緒能夠更改HashTable。就是說任何執行緒要更新HashTable時要首先獲得同步鎖,其它執行緒要等到同步鎖被釋放之後才能再次獲得同步鎖更新HashTable。
2) Fail-safe和iterator迭代器相關。如果某個集合物件建立了Iterator或者ListIterator,然後其它的執行緒試圖“結構上”更改集合物件,將會丟擲ConcurrentModificationException異常。但其它執行緒可以通過set()方法更改集合物件是允許的,因為這並沒有從“結構上”更改集合。但是假如已經從結構上進行了更改,再呼叫set()方法,將會丟擲IllegalArgumentException異常。
3) 結構上的更改指的是刪除或者插入一個元素,這樣會影響到map的結構。
我們能否讓HashMap同步?
HashMap可以通過下面的語句進行同步:
Map m = Collections.synchronizeMap(hashMap);
結論
HashTable和HashMap有幾個主要的不同:執行緒安全以及速度。僅在你需要完全的執行緒安全的時候使用HashTable,而如果你使用Java 5或以上的話,請使用ConcurrentHashMap吧。
原文連結: Javarevisited 翻譯: ImportNew.com - 唐小娟
相關文章
- HashMap、HashTable、ConcurrentHashMap的區別HashMap
- C#中Hashtable和HashMap的區別C#HashMap
- java複習之HashMap和Hashtable的區別JavaHashMap
- HashMap、Hashtable、ConcurrentHashMap的原理與區別HashMap
- 集合類HashMap,HashTable,ConcurrentHashMap區別?HashMap
- HashMap底層實現原理/HashMap與HashTable區別/HashMap與HashSet區別HashMap
- Hashtable和HashMapHashMap
- HashTable、ConcurrentHashMap、TreeMap、HashMap關於鍵值的區別HashMap
- 10分鐘掌握ConcurrentHashMap 3分鐘清楚和HashMap、Hashtable的區別HashMap
- 五分鐘看懂Hashtable原始碼以及與HashMap的區別原始碼HashMap
- Java集合系列(四):HashMap、Hashtable、LinkedHashMap、TreeMap的使用方法及區別JavaHashMap
- HashTable與ConcurrentHashMap的區別HashMap
- Java集合詳解4:一文讀懂HashMap和HashTable的區別以及常見面試題JavaHashMap面試題
- 【java】【Map】HashMap、Hashtable、CollectionsJavaHashMap
- 三,TreeMap和HashMap,TreeSet和HashMap的區別以及方法使用上的不同HashMap
- 一文讀懂JDK7,8,9的hashmap,hashtable,concurrenthashmap及他們的區別JDKHashMap
- HashMap、LinkedHashMap、HashTable、HashSet筆記HashMap筆記
- HashSet與HashMap的區別HashMap
- Hashtable/HashMap與key/value為null的關係HashMapNull
- 一文讀懂JDK1.7,JDK1.8,JDK1.9的hashmap,hashtable,concurrenthashmap及他們的區別JDKHashMap
- HashMap為何執行緒不安全?HashMap,HashTable,ConcurrentHashMap對比HashMap執行緒
- Java中HashMap,LinkedHashMap,TreeMap的區別[轉]JavaHashMap
- HashSet/HashMap、TreeSet/TreeMap、LinkedHashSet/LinkedHashMap 區別HashMap
- 一文讀懂JDK7,8,9的hashmap,hashtable,concJDKHashMap
- 你真的瞭解HashSet 和HashMap的區別、優缺點、使用場景嗎?HashMap
- ../和./和/的區別
- LinkedList和ArrayList的區別、Vector和ArrayList的區別
- http和https的區別/get和post的區別HTTP
- 為什麼hashtable不允許設定Null但是hashmap允許?NullHashMap
- ||和??的區別
- /*和/**的區別
- 美團面試題:Hashmap的結構,1.7和1.8有哪些區別(史上最深入的分析)面試題HashMap
- HashMap匿名初始化和日期的時區問題HashMap
- jquery $(this) 和this的區別jQuery
- JQuery this和$(this)的區別jQuery
- T和?的區別
- makefile =和:=的區別
- ++a和a++的區別
- ./ 和sh 的區別