1.存储:HashMap中key和value都允许为null
2.线程安全:HashMap线程不安全的,而Hashtable线程安全的,因为所以方法都是Synchronize的。
3.hash值不同:
哈希值的使用不同,HashTable直接使用对象的hashCode。而HashMap重新计算hash值。
hashCode是jdk根据对象的地址或者字符串或者数字算出来的int类型的数值。
Hashtable计算hash值,直接用key的hashCode(),而HashMap重新计算了key的hash值,Hashtable在求 hash值对应的位置索引时,用取模运算,而HashMap在求位置索引时,则用与运算,且这里一般先用 hash&0x7FFFFFFF后,再对length取模,&0x7FFFFFFF的目的是为了将负的hash值转化为正值,因为hash值 有可 能为负数,而&0x7FFFFFFF后,只有符号外改变,而后面的位都不变。
4.内部实现使用的数组初始化和扩容方式不同
HashTable在不指定容量的情况下的默认容量为11,而HashMap为16,Hashtable不要求底层数组的容量 一定要为2的整数次幂,而HashMap则要求一定为2的整数次幂。
Hashtable扩容时,将容量变为原来的2倍加1,而HashMap扩容时,将容量变为原来的2倍。
Hashtable和HashMap它们两个内部实现方式的数组的初始大小和扩容的方式。HashTable中hash数组默认大 ,增加的方式是 old*2+1。
2.线程安全:HashMap线程不安全的,而Hashtable线程安全的,因为所以方法都是Synchronize的。
3.hash值不同:
哈希值的使用不同,HashTable直接使用对象的hashCode。而HashMap重新计算hash值。
hashCode是jdk根据对象的地址或者字符串或者数字算出来的int类型的数值。
Hashtable计算hash值,直接用key的hashCode(),而HashMap重新计算了key的hash值,Hashtable在求 hash值对应的位置索引时,用取模运算,而HashMap在求位置索引时,则用与运算,且这里一般先用 hash&0x7FFFFFFF后,再对length取模,&0x7FFFFFFF的目的是为了将负的hash值转化为正值,因为hash值 有可 能为负数,而&0x7FFFFFFF后,只有符号外改变,而后面的位都不变。
4.内部实现使用的数组初始化和扩容方式不同
HashTable在不指定容量的情况下的默认容量为11,而HashMap为16,Hashtable不要求底层数组的容量 一定要为2的整数次幂,而HashMap则要求一定为2的整数次幂。
Hashtable扩容时,将容量变为原来的2倍加1,而HashMap扩容时,将容量变为原来的2倍。
Hashtable和HashMap它们两个内部实现方式的数组的初始大小和扩容的方式。HashTable中hash数组默认大 ,增加的方式是 old*2+1。