一、继承不同,HashTable 继承自 Dictionary 类,而 HashMap 是 Java1.2 引进的 Map interface 的一个实现。
二、Hashtable中的方法是同步的,而Hashmap中的方法在缺省情况下是非同步的。在多线程并发的环境下,可以直接使用Hash table。Hashtable的实现方法里面都添加了synchronized关键字来确保线程同步。但是使用Hashmap的话,就要自己增加同步处理了。
三、HashMap允许将 null 作为一个 entry 的 key 或者 value,而 Hashtable 不允许。在HashMap中null可以作为键,这样的键只有一个,可以有一个或多个键所对应的值为null。HashMap 把 Hashtable 的 contains 方法去掉了,改成 containsValue 和 containsKey。
四、两者在遍历方式的实现上不同,Hashtable和HashMap都使用了Iterator。而由于历史原因,HashTable还使用了Enumeration的方式,另一个区别是HashMap的迭代器是fail-fast迭代器,而HashTable的enumeration迭代器不是fail-fast的。
五、哈希值的使用不同,Hashtable直接使用对象的HashCode,而HashMap重新计算哈希值。
六、HashTable和HashMap内部实现的数组初始大小和扩容的方式。HashTable中hash数组默认大小是11,增加的方式是old*2 + 1,而HashMap的是翻倍。HashMap中hash数组的默认大小是16,而且一定是2的指数。
七、HashTable在求数组下标是通过初一length取余,而HashMap是与length - 1进行与。