Java中的HashMap和Hashtable的区别

1 该类HashMap大致相当于Hashtable,除了它是非同步的并且允许空值。(HashMap允许空值作为键和值,而Hashtable不允许nulls)。
2 HashMap不保证地图的顺序会随着时间的推移保持不变。
3 HashMap是非同步的,Hashtable而是同步的。
中的迭代器HashMap是故障安全的,而枚举Hashtable器不是,并且ConcurrentModificationException如果任何其他线程通过添加或删除除Iterator自己的remove() 方法之外的任何元素来在结构上修改映射,则抛出异常。但这不是保证行为,JVM 会尽最大努力来完成。
一些重要术语的注意事项:

同步意味着只有一个线程可以在一个时间点修改哈希表。基本上,这意味着任何线程在对 a 执行更新之前Hashtable都必须获取对象上的锁,而其他线程将等待锁被释放。
故障安全在迭代器的上下文中是相关的。如果在集合对象上创建了一个迭代器,并且某个其他线程试图“结构化地”修改集合对象,则会引发并发修改异常。其他线程可以调用该set方法,因为它不会“结构地”修改集合。但是,如果在调用之前set,集合已经在结构上进行了修改,IllegalArgumentException则会被抛出。
结构修改是指删除或插入可以有效改变地图结构的元素。
HashMap可以通过同步

Map m = Collections.synchronizeMap(hashMap);

Map 提供 Collection 视图,而不是通过 Enumeration 对象直接支持迭代。集合视图极大地增强了界面的表现力,这将在本节后面讨论。Map 允许您迭代键、值或键值对;Hashtable不提供第三种选择。Map 提供了一种在迭代过程中删除条目的安全方法;Hashtable没有。Hashtable最后,Map 修复了界面中的一个小缺陷。Hashtable有一个名为 contains 的方法,如果Hashtable包含给定值,则返回 true。鉴于它的名称,如果包含给定的键,您会期望此方法返回 true,Hashtable因为该键是 a 的主要访问机制Hashtable。Map 接口通过重命名方法消除了这种混淆来源containsValue. 此外,这提高了界面的一致性containsValue——parallels containsKey。

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值