Hashtable和HashMap類的作用一樣,都是用來存儲kv對。實際上,它們擁有相同的接口。Hashtable和HashMap的區(qū)別如下:
- Hashtable的方法是同步的,HashMap的方法不是同步的。這是兩者最主要的區(qū)別。
這就意味著Hashtable是線程安全的,HashMap不是線程安全的。HashMap效率較高,Hashtable效率較低。
如果對同步性或與遺留代碼的兼容性沒有任何要求,建議使用HashMap。
查看Hashtable的源代碼就可以發(fā)現(xiàn),除構(gòu)造函數(shù)外,Hashtable的所有 public 方法聲明中都有 synchronized關(guān)鍵字,而HashMap的源碼中則沒有。
Hashtable不允許null值,HashMap允許null值(key和value都允許)
父類不同:Hashtable的父類是Dictionary,HashMap的父類是AbstractMap
Hashtable中hash數(shù)組默認(rèn)大小是11,增加的方式是 old*2+1。HashMap中hash數(shù)組的默認(rèn)大小是16,而且一定是2的指數(shù)。