本篇文章為大家展示了如何用源碼分析HashSet,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。
10余年建站經(jīng)驗, 成都做網(wǎng)站、網(wǎng)站制作、成都外貿(mào)網(wǎng)站建設客戶的見證與正確選擇。創(chuàng)新互聯(lián)提供完善的營銷型網(wǎng)頁建站明細報價表。后期開發(fā)更加便捷高效,我們致力于追求更美、更快、更規(guī)范。
public class HashSet<E> extends AbstractSet<E> implements Set<E>, Cloneable, Serializable { }
HashSet繼承了AbstractSet,實現(xiàn)了Set; 是一個由HashMap實現(xiàn)的沒有重復元素的集合
不保證元素順序,允許使用null元素
HashSet實現(xiàn)了Cloneable接口,重寫了clone方法,因此可以進行克隆。
HashSet實現(xiàn)了Serializable接口,因此可以進行序列化。
HashSet的操作是非線程安全的
/** 具體存儲HashSet元素的HashMap **/ private transient HashMap<E, Object> map; /** 由于Set只用到了HashMap的key 所以用PRESENT來填充HashMap的Value **/ private static final Object PRESENT = new Object();
/** 默認構造函數(shù) 采用HashMap的默認構造函數(shù) **/ public HashSet() { map = new HashMap<>(); } /** 通過集合構造HashSet 先根據(jù)集合大小計算HashMap的大小值 初始化HashMap后將集合元素全部添加進去 **/ public HashSet(Collection<? extends E> c) { map = new HashMap<>(Math.max((int) (c.size()/.75f) + 1, 16)); addAll(c); } /** 根據(jù)初始化容量構造HashMap **/ public HashSet(int initialCapacity) { map = new HashMap<>(initialCapacity); } /** 根據(jù)初始化容量和加載因子構造HashMap **/ public HashSet(int initialCapacity, float loadFactor) { map = new HashMap<>(initialCapacity, loadFactor); } /** 同上面構造函數(shù) dummy參數(shù)無實際意義 主要供LinkedHashSet調用 底層采用LinkedHashMap **/ HashSet(int initialCapacity, float loadFactor, boolean dummy) { map = new LinkedHashMap<>(initialCapacity, loadFactor); }
由于底層采用HashMap 構造函數(shù)主要構造HashMap。
最后一個構造函數(shù)主要供子類LinkedHashSet調用,底層采用LinkedHashMap
/** 添加元素 通過HashMap的put方法實現(xiàn) **/ 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 boolean contains(Object o) { return map.containsKey(o); }
/** 返回迭代器 **/ public Iterator<E> iterator() { return map.keySet().iterator(); } /** 獲取HashSet中元素的數(shù)量 **/ public int size() { return map.size(); } /** 返回HashSet中是否是空的 **/ public boolean isEmpty() { return map.isEmpty(); }
上述內容就是如何用源碼分析HashSet,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
本文標題:如何用源碼分析HashSet
瀏覽路徑:http://aaarwkj.com/article8/peship.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站建設、ChatGPT、響應式網(wǎng)站、網(wǎng)站策劃、品牌網(wǎng)站設計、靜態(tài)網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)