1.二者的存储结构和解决冲突的方法都是相同的。
2、继承的父类不同:Hashtable继承自Dictionary类,而HashMap继承自AbstractMap类。但二者都实现了Map接口。
3.HashTable 中 key和 value都不允许为 null,而HashMap中key和value都允许为 null(key只能有一个为null,而value则可以有多个为 null)。但是如果在 Hashtable中有类似 put( null, null)的操作,编译同样可以通过,因为 key和 value都是Object类型,但运行时会抛出 NullPointerException异常。
4.内部实现使用的数组初始化和扩容方式不同:HashTable在不指定容量的情况下的默认容量为11,而HashMap为16,Hashtable不要求底层数组的容量一定要为2的整数次幂,而HashMap则要求一定为2的整数次幂。Hashtable扩容时,将容量变为原来的2倍加1,而HashMap扩容时,将容量变为原来的2倍。
5、线程安全性不同:Hashtable是线程安全,而HashMap则非线程安全。Hashtable的实现方法里面都添加了synchronized关键字来确保线程同步,因此相对而言HashMap性能会高一些,我们平时使用时若无特殊需求建议使用HashMap
hashmap在java7和java8是有区别的,想具体深入了解的可以看这篇文章
https://blog.csdn.net/bird_tp/article/details/112600190
想简单了解hashmap的可以阅读这篇文章
https://blog.csdn.net/weixin_35586546/article/details/81153793?spm=1001.2014.3001.5501