`
tjc
  • 浏览: 66743 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

HashTable HashMap HashSet difference

JDK 
阅读更多
JDK 1.6.0 API:
引用

public class Hashtable<K,V>
extends Dictionary<K,V>
implements Map<K,V>, Cloneable, Serializable
此类实现一个哈希表,该哈希表将键映射到相应的值。任何非 null 对象都可以用作键或值。
为了成功地在哈希表中存储和获取对象,用作键的对象必须实现 hashCode 方法和 equals 方法。Hashtable 是同步的。

public class HashMap<K,V>
extends AbstractMap<K,V>
implements Map<K,V>, Cloneable, Serializable
基于哈希表的 Map 接口的实现。此实现提供所有可选的映射操作,并允许使用 null 值和 null 键。(除了非同步和允许使用 null 之外,HashMap 类与 Hashtable 大致相同。)此类不保证映射的顺序,特别是它不保证该顺序恒久不变。
注意,此实现不是同步的。

public class HashSet<E>
extends AbstractSet<E>
implements Set<E>, Cloneable, Serializable
此类实现 Set 接口,由哈希表(实际上是一个 HashMap 实例)支持。它不保证 set 的迭代顺序;特别是它不保证该顺序恒久不变。此类允许使用 null 元素。
注意,此实现不是同步的。


总结:
     ☆☆☆HashTable 是同步的,HashMap不是同步的,由于HashSet需要HashMap的支持,所以HashSet也不是同步的。
     ☆☆☆HashTable 和 HashMap都是以键值对<K,V>进行存储,但是HashTable不允许使用null 值和键,而HashMap是允许的;HashSet是一系列不重复对象的集合,允许存储null 元素。

引用
Set集合是不包含重复元素的,List则可以包含重复元素,Map是键-值的映射关系
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics