浅谈HashMap与Hashtable的异同

浅谈HashMap与Hashtable的异同

在查阅参考了好多文章和资源后,自己再总结了下这两者的区别。

首先他们都实现了Map接口,HashMap几乎跟Hashtable(注意它的写法是Hashtable ,小写的“t”)一样,HashMap比Hashtable出现的要迟。主要的区别有:同步(synchronization)与线程安全性,性能与速度以及是否可以为空值null。
1.同步与线程安全性:
HashMap是非synchronized的,线程不安全,如果没有正确同步的话,多个线程不能共享一个HashMap;
Hashtable是synchronized的,线程安全,多个线程可以共享一个Hashtable;Hashtable是个过时的集合类,在Java 4中被重写了,实现了Map接口,所以也是Java集合框架中的一部分。Java 5提供了ConcurrentHashMap,它是HashTable的替代,比HashTable的扩展性更好。
2.性能与速度:
由于Hashtable是线程安全的也是synchronized,所以在单线程环境下,如果不需要同步的话,HashMap性能比Hashtable更好。
3.是否取空值null:
HashMap的key值和value值都可以为null,但最多只有1个key值可以为null,可以多个value值为空,也就是key是唯一不重复的,value可重复;
而Hashtable的key值和value值都不可以为null
4. 迭代器
HashMap的迭代器(Iterator)是fail-fast迭代器,而Hashtable的迭代器(enumerator)不是fail-fast的。当有其它线程改变了HashMap的结构(增加或者移除元素),将会抛出ConcurrentModificationException,但迭代器本身的remove()方法移除元素则不会抛出ConcurrentModificationException异常。但这并不是一个一定发生的行为,要看JVM。
5.其他
我们能否让HashMap同步?
HashMap可以通过Collections工具类的Collections.synchronizeMap(hashMap)方法进行同步:
Map m = Collections.synchronizeMap(hashMap);
重要术语:
 sychronized意味着在一次仅有一个线程能够更改Hashtable。就是说任何线程要更新Hashtable时要首先获得同步锁,其它线程要等到同步锁被释放之后才能再次获得同步锁更新Hashtable。

原文链接: Javarevisited 翻译: ImportNew.com - 唐小娟
译文链接: http://www.importnew.com/7010.html
[ 转载请保留原文出处、译者和译文链接]

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值