当前位置: 代码迷 >> 综合 >> Collection--HashMap与HashTable的区别
  详细解决方案

Collection--HashMap与HashTable的区别

热度:26   发布时间:2023-11-23 10:25:37.0
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。
  相关解决方案