1. 程式人生 > >(轉)HashMap和HashTable的區別

(轉)HashMap和HashTable的區別

http://www.importnew.com/7010.html

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吧。

相關推薦

()HashMapHashTable區別

http://www.importnew.com/7010.htmlHashMap和HashTable的比較是Java面試中的常見問題,用來考驗程式設計師是否能夠正確使用集合類以及是否可以隨機應變使用多種思路解決問題。HashMap的工作原理、ArrayList與Vector

HashMap HashTable 區別

AC n) ati 只需要 試圖 external str enume 時間 來源:http://www.importnew.com/7010.html HashMap和Hashtable的區別 HashMap和Hashtable都實現了Map接口,但決定用哪一個之前先要弄

HashMapHashtable區別

-- 其它 serial on() 很大的 程序 fas cloneabl was 1. 類定義 這個從源碼中可以直接看出來,HashMap 繼承自 AbstractMap,而 Hashtabl 繼承自 Dictionary。 public class HashMap<

HashMapHashTable區別及Hash衝突解決方法

一、HashMap和HashTable主要有以下5個方面的區別: 1.繼承的父類不同   Hashtable繼承自Dictionary類,而HashMap繼承自AbstractMap類。但二者都實現了Map介面。 2.對null物件的支援不同   HashMap是支援

HashMapHashtable 區別

Hashtable是執行緒安全,而HashMap則非執行緒安全 Hashtable的實現方法裡面都添加了sy

ArrayListVector的區別,HashMapHashtable區別以及執行緒安全的理解【

http://www.cnblogs.com/xionglee/articles/1554701.html 就ArrayList與Vector主要從二方面來說. 一.同步性:Vector是執行緒安全的,也就是說是同步的,而ArrayList是執行緒序不安全的,不是同步的 二.資料增長:當需要增長時,Ve

HashMapHashtable區別

性能 刪除 影響 之間 fail 創建 允許 hashmap 以及 HashMap和Hashtable都實現了Map接口,但決定用哪一個之前先要弄清楚它們之間的分別。主要的區別有:線程安全性,同步(synchronization),以及速度。 HashMap幾乎可以等價於

淺析HashMapHashtable區別

兩個 ble dem pub 實現 value key-value span div HashMap和Hashtable兩個類都實現了Map接口,二者保存鍵值對(key-value對); HashMap和HashTable區別 第一,繼承的父類不同。HashMap繼承自A

java 的HashMapHashTable區別

鏈表結構 線程 數組 操作 map 內部實現 鏈表 hashmap lin  1.HashMap和HashTable的區別?    HashMap不是線程安全的它的操作方法沒有進行同步處理    HashMap允許key為空        HashTable是線程安全的它的

HashMapHashtable有什麽區別

map tab ble 線程 table ash 什麽 shm 多線程 HashMap和Hashtable都是實現Map接口的,但是:   1.HashMap允許鍵和值都是null的,而Hashtable不允許鍵和值為null   2.Hashtable是同步的,而Hash

HashMap底層實現原理/HashMapHashTable區別/HashMap與HashSet區別

eem 實現原理 ger 銀行 索引 target 聲明 到你 們的 ①HashMap的工作原理 HashMap基於hashing原理,我們通過put()和get()方法儲存和獲取對象。當我們將鍵值對傳遞給put()方法時,它調用鍵對象的hashCode()方法來計算has

HashMapHashtable區別 學習筆記

ble new map 面試題 學習筆記 ring println 線程 1.2 /** * @param args * 面試題 * HashMap和Hashtable的區別 * 共同點: * 底層都是哈希算法,都是雙列集合

【java】 HashMap的工作原理+HashMapHashtable區別+HashMapHashSet的區別

本文由 ImportNew - 唐小娟 翻譯自 Javarevisited。 HashMap的工作原理是近年來常見的Java面試題。幾乎每個Java程式設計師都知道HashMap,都知道哪裡要用HashMap,知道Hashtable和HashMa

關於hashmaphashtable區別,及如何使hashmap變得執行緒安全?(除了synchronized)---concurrentHashmap

我們都知道hashmap是執行緒不安全的,而效率也比較高,他允許我們存入null鍵及null值; 而 hashtable 是執行緒安全的,其效率比較低,不允許我們存入null鍵和null值; 除了非同步及允許使用null值,hashmap與hashtable基本相同; 那麼為什麼hash

深度理解 HashMap Hashtable區別

這只是基礎: HashMap 和 Hashtable 都實現了 Map 介面,因此很多特性非常相似。但是,他們有以下不同點: HashMap 允許鍵和值是 null,而 Hashtable 不允許鍵或者值是 null。 Hashtable 是同步的,而 HashMap 不是。因此, Hash

HashMap Hashtable 的 6 個區別,最後一個沒幾個人知道!

HashMap 和 Hashtable 是 Java 開發程式設計師必須要掌握的,也是在各種 Java 面試場合中必須會問到的。 但你對這兩者的區別瞭解有多少呢? 現在,棧長我給大家總結一下,或許有你不明朗的地方,在棧長的指點下都會撥開迷霧見晴天。 1、執行緒安全 Hashtable 是執行緒安全的,Hash

HashMap Hashtable 的 6 個區別

HashMap 和 Hashtable 是 Java 開發程式設計師必須要掌握的,也是在各種 Java 面試場合中必須會問到的。 但你對這兩者的區別瞭解有多少呢? 現在,棧長我給大家總結一下,或許有你不明朗的地方,在棧長的指點下都會撥開迷霧見晴天。 1、執行緒安全 Hashtable

HashMapHashTable區別

區別 執行緒安全問題 Hashtable是執行緒安全的,它的每個方法中都加入了Synchronize方法。在多執行緒併發的環境下,可以直接使用Hashtable,不需要自己為它的方法實現同步 HashMap不是執行緒安全的,在多執行緒併發的環境下,可能會

java:集合框架(HashMapHashtable區別)

* HashMap和Hashtable的區別         * Hashtable是JDK1.0版本出現的,是執行緒安全的,效率低,HashMap是JDK1.2版本出現的,是執行緒不安全的,效率高  

javaSE (二十七)HashMapHashtable區別、用集合模擬撲克牌鬥地主分發與檢視、集合總結

1、HashMap和Hashtable的區別: 共同點:底層都是雜湊演算法,都是雙列集合 不同點: HashMap是執行緒不安全的,效率高,JDK1.2版本,可以儲存null鍵和值 HashMap是執行緒安全的,效率低,JDK1.0版本,不可以儲存null鍵和值