HashTble和HashMap都实现了Map接口,但是它们也有很多区别
HashTble和HashMap的区别主要的以下几点:
1、HashTable是线程安全的,因为它的大部分方法使用了Sychronized进行修饰,所以它的方法能够进行同步,从而保证线程安全性,
HashMap的方法没有使用Sychronized修饰,所以不能保证线程的安全,
如果HashMap想要保证方法同步,可以使用语句Map map = Collections.sychronizedMap(hashmap),如果是JDK5以上,可以使用CuncurrentHashMap;
2、HashTable不能存储键值对为null的数据,而HashMap可以;
3、HashTble和HashMap内部计算hash值的方法不同;
4、HashTble使用Enumeration迭代器,HashMap使用Iterator迭代器,后者是一种fail-fash迭代器,这种迭代器当集合对象创建了Iterator或者ListIterator后,
再试图改变集合的话,会抛出ConcurrentModificationException异常;
5、HashTable中hash数组默认大小是11,增加的方式是old*2+1。HashMap中hash数组的默认大小是16,而且一定是2的指数
6、HashTable继承自Dictionary类,而HashMap继承自AbstractMap类;