1、线程是否安全:HashMap是非线程安全的,HashTable是线程安全的;HashTable内部的方法基本上都经过synchronized修饰。(如果你要保保证线程安全监视使用ConcurrentHashMap);
2、效率:因为线程安全的问题,HashMap要比HashTable的效率高一些,另外HashTable基本被淘汰,不建议在代码中使用;
3、对Null key和Null value的支持:在HashMap中Null可以为主键,但这样的键只能有一个,可以有一个或多键所对应的值为null。但是在HashTable中put进的键值只要有一个null,直接抛出NullPointerException;
4、初始容量大小和每次扩容容量大小不同:创建时如果不指定容量的初始值,HashMap默认的初始化大小为16,之后每次扩容容量变为原来的两倍。HashTable默认的初始大小为11,之后每次扩容,容量变为原来的2n+1;创建时如果给定了容量的初始值,那么HashTable会直接使用你给定的大小,而HashMap会将其扩充为2的幂次方大小;
5、底层数据结构:JDK1.8以后的HashMap在解决哈希冲突时有了较大的变化,当链表长度大于阈值(默认为8)时,将链表转化为红黑树,以减少搜索时间。HashTable没有这样的机制;