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值
只是列出不同点,详细的区别会慢慢补充...