码迷,mamicode.com
首页 > 其他好文 > 详细

HashMap 和 Hashtable 的区别?

时间:2015-06-09 17:28:17      阅读:142      评论:0      收藏:0      [点我收藏+]

标签: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的指数。

HashMap 和 Hashtable 的区别?

标签:java基础疑难解答   hashtable   hashmap   

原文地址:http://blog.csdn.net/uniquewonderq/article/details/46426617

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!