HashMap与Hashtable的区别

HashMap与Hashtable的区别

1.继承的父类不同:

HashTable的父类是Dictionary

HashMap的父类是AbstractMap;

2.线程安全性:

HashTable:线程安全,HashTable方法有synchronized修饰

HashMap:线程不安全

3.contains()

HashTable:保留了contains(),containsKey(),containsValue()

HashMap:去掉了contains(),保留了containsKey(),containsValue()

4.key,value是否能为null

HashTable:key,value都不能为空.原因是源码中方法里会遍历entry,然后用entry的key或者value调用equals(),所以要先判断key/value是否为空,如果为空就会抛出异常

HashMap:key,value可以为空.null作为key只能有一个,null作为value可以存在多个

5.遍历方式的内部实现不同

HashTable:使用Enumeration,Iterator

HashMap:使用Iterator

6.内部实现使用的数组初始化和扩容方式不同

HashTable:数组初始大小为11,扩容方式为2*old+1

HashMap:数组初始大小为16,扩容方式为2的指数幂形式

7.hash值不同

HashTable: 直接使用hashcode()

HashMap:重新计算hash值

 

只是列出不同点,详细的区别会慢慢补充...

 

posted @ 2018-01-25 09:29  KristinLee  阅读(224)  评论(0编辑  收藏  举报
jQuery火箭图标返回顶部代码