您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關HashMap與HashTable有什么區別的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
HashMap 不是線程安全的。
HashMap 做 put 操作時,兩個線程同時進入 addEntry 操作,計算出相同的 hash 值,A線程寫入頭節點之后,B線程也寫入頭節點,那么A的操作就會被覆蓋,造成A的寫入操作丟失。
Vector 和 HashTable,concurrentHashMap,copyOnwriteArrayList時線程安全的。
繼承不同。HashMap 是繼承自 AbstractMap 類,而 HashTable 是繼承自 Dictionary 類。
HashTable 中的方法是同步的,HashMap 是非同步的。HashTable 的實現方法里面都添加了 synchronized 關鍵字來確保同步,使用HashMap的話就要自己增加同步處理。同步方法 Map m = Collections.synchronizeMap(hashMap);
HashTable 中,K,V都不允許出現null;HashMap中,null 可以作為鍵,這樣的鍵只有一個,為 null 的值可以有一個或多個。(HashMap中不能用get()來判斷是否存在某個鍵,應該用containsKey() )
遍歷方式。HashMap、HashTable 都使用了 Iterator 。由于歷史原因 HashTable 還使用了 Enumeration 的方式。Iterator 的迭代器是 fail-fast 迭代器,而 Enumeration 不是。
hash值的使用不同。HashTable 直接使用對象的 Hashcode,HashMap 重新計算 hash值。
數組的初始大小和擴容方式不同。HashTable 的數組默認大小是11,擴容方式是 old * 2 + 1。HashMap 中數組默認大小是16,擴容方式是 2 的指數次冪。
求數組下標方式不同。hashTable 通過除以 length 取余,hashMap是與 length - 1 進行按位與運算。
感謝各位的閱讀!關于“HashMap與HashTable有什么區別”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。