标签:java基础疑难解答 hashtable hashmap
二者都实现了 Map 接口,是将惟一键映射到特定的值上;主要区别在于:
1)HashMap 没有排序,允许一个 null 键和多个 null 值,而 Hashtable 不允许;
当get()方法返回null值时,既可以表示HashMap中没有改键,也可以表示改建所对应的值为null。一次hasomap中不能由get()方法来判断hashmap对象中是否存在某个键,应该是哟好难过containkey()方法来判断。
2)HashMap 把 Hashtable 的 contains 方法去掉了,改成 containsvalue 和
containsKey,因为 contains 方法容易让人引起误解;
3)Hashtable 继承自 Dictionary 类 ,HashMap 是 Java1.2 引进的 Map 接口的实现 ;
public class Hashtable extends Dictionary implenments Map
public class HashMap extends AbstractMap implements Map
4)Hashtable 的方法是 Synchronize 的,而 HashMap 不是,在多个线程访问
Hashtable 时,不需要自己为它的方法实现同步,而 HashMap 就必须为之提供外
同步。
5)遍历时,都是用了Iterator迭代器,而hashtable还使用了enumeration()方法。
6) 哈希值的使用不同,hashtable直接使用对象的hashcode而HashMap重新计算hash值、
7)hashtable和hashmap他们两个内部实现方式的数组初始大小和扩容方式不同,hashtable中数组的默认大小是11,增加方式:old*2+1;HashMap中hash数组默认大小是16,而且一定是2的指数。
标签:java基础疑难解答 hashtable hashmap
原文地址:http://blog.csdn.net/uniquewonderq/article/details/46426617