HashMap和HashTable的区别
1.HashTable的方法是同步的,HashMap未经同步,所以在多线程场合要动手同步HashMap这个区别就像Vector和ArrayList。
2.HashTable不允许null值(key和value都不可以),HashMap允许null值(key和value都可以)
3.两者的遍历方式大同小异,HashTable仅仅比HashMap多一个elements的方法。
HashTable和HashMap都能通过values()方法返回一个Collection,然后进行遍历处理。
两者也都可以通过entrySet()方法返回一个Set,然后进行遍历处理。
4.HashTable使用Enumeration,HashMap使用Iterator。
5.哈希值的使用不同,HashTable直接使用对象的hashcode。而HashMap则重新计算hash值,而且用于代替求模。
6.HashTable中hash数组默认大小是11,增加的方式是2*old+1。HashMap中hash数组的默认大小是16,而且一定是2的指数。
7.HashTable基于Dictionary类,而HashMap基于AbstarctMap类。
HashMap中的key可以是任何对象或数据类型么?
1.可以为null,但是不能是可变对象,如果是可变对象的话,对象中的属性改变,则对象的hashcode也进行了相应的改变,导致下次无法查找到已存在Map中的数据。
2.如果可变对象在HashMap中被用作键,那就要小心在改变对象状态的时候,不要改变它的哈希值了。我们只需要保证成员变量的改变能保证该对象的哈希值不变即可。
HashTable是线程安全的么?
HashTable是线程安全的,其实现是在对应的方法上添加了synchronized关键字进行修饰,由于在执行此方法的时候需要获得对象锁,则执行起来比较慢。所以现在如果为了保证线程安全的话,使用ConcurrentHashMap。