`
我是小仙321
  • 浏览: 13059 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

HashMap和HashTable的区别总结

    博客分类:
  • Java
阅读更多

HashMap和HashTable的区别:
看了网上的很多说法,总结起来大概是:
1.历史原因。Hashtable是基于陈旧的Dictionary类的,HashMap是Java 1.2引进的Map接口的一个实现。
2.同异步问题。Hashtable是同步的,而HashMap是异步的。用Hashtable时,同步的一个时间段里只能一个人访问所以效率要低。但是它保证了数据的一致性和唯一性。多个线程访问HashMap时,需要为它提供外同步,而Hashtable则不需要为它提供同步。一个方便的方法就是利用Collections类的静态的synchronizedMap()方法,它创建一个线程安全的Map对象,并把它作为一个封装的对象来返回。这个对象的方法可以让你同步访问潜在的HashMap。这么做的结果就是当你不需要同步时,你不能切断Hashtable中的同步(比如在一个单线程的应用程序中),而且同步增加了很多处理费用。
3.有关null。Hashtable中不允许null作为key和value。而HashMap中允许最多一个null的key,和任意个null的value。
需要注意的是,在Hashtable中,

flag[2]=ht1.containsValue(null);

flag[3]=ht1.contains(null);

flag[4]=ht1.containsKey(null);

也是有异常的。

PS:在这儿的时候增长了一个知识,当用Enumeration en=ht1.keys()时,keys在en里是倒序的。

如:         ht1.put("1","a");

ht1.put("2", "b");

ht1.put("3", "c");

那么en.nextElement(),第一个结果是“3”。

4.关于方法。看到有的地方说,HashMap把Hashtable的contains方法去掉了,改成containsvalue和containsKey。其实在Hashtable中也是有containsvalue和containsKey的。
5.关于使用哪一个。一些资料建议,当需要同步时,用Hashtable,反之用HashMap。但是,因为在需要时,HashMap可以被同步,HashMap的功能比Hashtable的功能更多,而且它不是基于一个陈旧的类的,所以有人认为,在各种情况下,HashMap都优先于Hashtable。

 

还有其他的区别吗?请大家给予补充和指正~

 

转载请注明来自:http://java-future.iteye.com

7
6
分享到:
评论
1 楼 TeacherMao 2013-03-26  
其实,Hashtable也是Map接口的一个实现

相关推荐

Global site tag (gtag.js) - Google Analytics