`
oznyang
  • 浏览: 158933 次
  • 性别: Icon_minigender_1
  • 来自: 南京
文章分类
社区版块
存档分类
最新评论

HashMap与Hashtable的区别

阅读更多
HashTable的应用非常广泛,HashMap是新框架中用来代替HashTable的类,也就是说建议使用HashMap,不要使用HashTable。可能你觉得HashTable很好用,为什么不用呢?这里简单分析他们的区别。 
1.HashTable的方法是同步的,HashMap未经同步,所以在多线程场合要手动同步HashMap这个区别就像Vector和ArrayList一样。

2.HashTable不允许null值(key和value都不可以),HashMap允许null值(key和value都可以)。

3.HashTable有一个contains(Object value),功能和containsValue(Object value)功能一样。

4.HashTable使用Enumeration,HashMap使用Iterator。

以上只是表面的不同,它们的实现也有很大的不同。

5.HashTable中hash数组默认大小是11,增加的方式是 old*2+1。HashMap中hash数组的默认大小是16,而且一定是2的指数。

6.哈希值的使用不同,HashTable直接使用对象的hashCode,代码是这样的:
int hash = key.hashCode();
int index = (hash & 0x7FFFFFFF) % tab.length;
而HashMap重新计算hash值,而且用与代替求模:
int hash = hash(k);
int i = indexFor(hash, table.length);

static int hash(Object x) {
  int h = x.hashCode();

  h += ~(h << 9);
  h ^= (h >>> 14);
  h += (h << 4);
  h ^= (h >>> 10);
  return h;
}
static int indexFor(int h, int length) {
  return h & (length-1);
}
以上只是一些比较突出的区别,当然他们的实现上还是有很多不同的,比如
HashMap对null的操作
分享到:
评论
12 楼 tianhandigeng 2014-07-27  
06年的博客了,跟jdk版本有关系,现在1.5之后的话对Hashtable进行重新改写了,第四条不同不适用了,Hashtable内部迭代器现在既实现了Enumration,又实现了Iterator
11 楼 Cupenoruler 2014-04-11  
w156445045 写道
呵呵,前几天笔试有这个问题,我直接写了HashTable用得很少,基本上用HashMap代替了. 汗...
longfeng0624 写道
为什么现在的学校里都不教这些啊 ````

那是因为学校的老师,没几个老师清楚这个~



这个属于经验性姿势,老师教你理论,公司教你经验~
10 楼 FX夜归人 2013-03-15  
面试题。只知道 HashTable 已过时(/废弃)
9 楼 showzh 2012-08-05  
8 楼 w156445045 2012-06-26  
呵呵,前几天笔试有这个问题,我直接写了HashTable用得很少,基本上用HashMap代替了. 汗...
longfeng0624 写道
为什么现在的学校里都不教这些啊 ````

那是因为学校的老师,没几个老师清楚这个~
7 楼 Ouvidia 2012-02-09  
昨天面试  没回答出来
6 楼 spring-china 2011-11-03  
呵呵,前几天笔试有这个问题,我直接写了HashTable用得很少,基本上用HashMap代替了. 汗...
5 楼 longfeng0624 2011-09-28  
为什么现在的学校里都不教这些啊 ````
4 楼 xtcpcgx 2010-08-26  
现在才来学习,学的真烂,呵呵
3 楼 贝壳水母 2010-05-25  
啊~终于看到答案鸟~
2 楼 yanlp 2010-01-14  
唉。我今天面试也不知道怎么写。
1 楼 TTLtry 2009-10-17  
笔试时候,看到这个题,真不知道如何思考,主要是平时对这方面的处理比较少

相关推荐

Global site tag (gtag.js) - Google Analytics