轉載自 http://zhangshixi.iteye.com/blog/673143java
1. HashSet概述:函數
HashSet實現Set接口,由哈希表(其實是一個HashMap實例)支持。它不保證set 的迭代順序;特別是它不保證該順序恆久不變。此類容許使用null元素。學習
2. HashSet的實現:測試
對於HashSet而言,它是基於HashMap實現的,HashSet底層使用HashMap來保存全部元素,所以HashSet 的實現比較簡單,相關HashSet的操做,基本上都是直接調用底層HashMap的相關方法來完成, HashSet的源代碼以下:spa
- public class HashSet<E>
- extends AbstractSet<E>
- implements Set<E>, Cloneable, java.io.Serializable
- {
- static final long serialVersionUID = -5024744406713321676L;
-
-
- private transient HashMap<E,Object> map;
-
-
- private static final Object PRESENT = new Object();
-
-
- public HashSet() {
- map = new HashMap<E,Object>();
- }
-
-
- public HashSet(Collection<? extends E> c) {
- map = new HashMap<E,Object>(Math.max((int) (c.size()/.75f) + 1, 16));
- addAll(c);
- }
-
-
- public HashSet(int initialCapacity, float loadFactor) {
- map = new HashMap<E,Object>(initialCapacity, loadFactor);
- }
-
-
- public HashSet(int initialCapacity) {
- map = new HashMap<E,Object>(initialCapacity);
- }
-
-
- HashSet(int initialCapacity, float loadFactor, boolean dummy) {
- map = new LinkedHashMap<E,Object>(initialCapacity, loadFactor);
- }
-
-
- public Iterator<E> iterator() {
- return map.keySet().iterator();
- }
-
-
- public int size() {
- return map.size();
- }
-
-
- public boolean isEmpty() {
- return map.isEmpty();
- }
-
-
- public boolean contains(Object o) {
- return map.containsKey(o);
- }
-
-
- public boolean add(E e) {
- return map.put(e, PRESENT)==null;
- }
-
-
- public boolean remove(Object o) {
- return map.remove(o)==PRESENT;
- }
-
-
- public void clear() {
- map.clear();
- }
-
-
- public Object clone() {
- try {
- HashSet<E> newSet = (HashSet<E>) super.clone();
- newSet.map = (HashMap<E, Object>) map.clone();
- return newSet;
- } catch (CloneNotSupportedException e) {
- throw new InternalError();
- }
- }
- }
3. 相關說明:對象
1) 相關HashMap的實現原理,請參考個人上一遍總結:深刻Java集合學習系列:HashMap的實現原理。blog
2) 對於HashSet中保存的對象,請注意正確重寫其equals和hashCode方法,以保證放入的對象的惟一性。接口