第六章 HashSet源碼解析

来源:http://www.cnblogs.com/java-zhao/archive/2016/01/07/5110953.html
-Advertisement-
Play Games

6.1、對於HashSet需要掌握以下幾點HashSet的創建:HashSet()往HashSet中添加單個對象:即add(E)方法刪除HashSet中的對象:即remove(Object key)方法判斷對象是否存在於HashSet中:containsKey(Object key)註:HashSe...


6.1、對於HashSet需要掌握以下幾點

  • HashSet的創建:HashSet()
  • 往HashSet中添加單個對象:即add(E)方法
  • 刪除HashSet中的對象:即remove(Object key)方法
  • 判斷對象是否存在於HashSet中:containsKey(Object key)

 註:HashSet沒有獲取單個對象的方法,需要使用iterator

 

6.2、構建HashSet

 源代碼:

    //HashSet底層數據結構:通過hashmap的key不可重覆的原則,使得存放入HashSet中的值不重覆
    private transient HashMap<E, Object> map;
    //預設的hashmap的value
    private static final Object PRESENT = new Object();
    /**
     * 可存放16個元素
     */
    public HashSet() {
        map = new HashMap<E, Object>();
    }
    /**
     * 指定hashset的容量和負載因數
     */
    public HashSet(int initialCapacity, float loadFactor) {
        map = new HashMap<E, Object>(initialCapacity, loadFactor);
    }
    /**
     * 指定hashset的容量
     */
    public HashSet(int initialCapacity) {
        map = new HashMap<E, Object>(initialCapacity);
    }
View Code

註:HashSet的底層是HashMap,其依靠HashMap的key不可重覆,來保證將來加入到HashSet中的元素也不重覆(會將元素作為key放到hashmap中,參照6.3)。

 

6.3、add(E e)

源代碼:

add(E e)

    /**
     * 往set中添加值
     */
    public boolean add(E e) {
        //查看hashmap的put方法,若覆蓋已有key的舊值,會返回舊值;若沒有相應的key則返回null
        return map.put(e, PRESENT) == null;
    }
View Code

註意:這裡調用了HashMap的put(K key, V value)

 

6.4、remove(Object key)

源代碼:

    /**
     * 刪除指定元素
     */
    public boolean remove(Object o) {
        return map.remove(o) == PRESENT;
    }
View Code

註:這裡調用了HashMap的remove(Object key)

 

6.5、contains(Object key)

源代碼:

    /**
     * set中是否包含指定元素
     */
    public boolean contains(Object o) {
        return map.containsKey(o);
    }
View Code

註意:這裡調用了HashMap的containsKey(Object key)

 

總結:

  • HashSet底層就是HashMap
  • 其依靠HashMap的key不可重覆,來保證將來加入到HashSet中的元素也不重覆(會將元素作為key放到hashmap中)
  • HashSet線程不安全

HashMap源碼解析:

http://www.cnblogs.com/java-zhao/p/5106189.html

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 最近遇到VS2013,在打開解決方案時,報如下錯誤:“未找到與約束ContractNameMicrosoft.Internal.VisualStudio.PlatformUI.ISolutionAttachedCollectionService RequiredTypeIdentity Micros...
  • #//*************************************************************#//編輯人:#//編輯單位:#//編輯作用:移動電腦到對應的OU下#//編製時間:2016.01.05#//******************************...
  • 以後SqlSugar所有更新都會在這個貼子更新SqlSugar是一款輕量級的MSSQL ORM ,除了具有媲美ADO的性能外還具有和EF相似簡單易用的語法。學習列表 0、功能更新1、SqlSugar基礎應用2、使用SqlSugar處理大數據3、使用SqlSugar實現Join待更新4、使用SqlSu...
  • 前一段時間在給移動端寫介面時遇到一個調用介面發送郵箱 session 一直獲取不到的問題。我來給遇到問題的同志們說一說自個在網上查了好多資料,問了一些朋友後。終於找到解決方案了。大家都知道webapi預設是不開啟session會話支持的。所以需要Global文件中要重寫方法如下: public o....
  • 平常我們在做多個條件判斷的時候喜歡用switch(表達式){ case : 常量1 表達式1; break; case : 常量2 表達式2; break; case : 常量3 表達式3; break;.... default: 常量4 表達式4;...
  • 由於工作中需要,我接觸了dsoframer控制項,我辦公電腦是64系統,在使用時,總是報沒有註冊類錯誤。我很是奇怪,dsoframer.ocx控制項我都註冊過的呀。然後在網上查閱了許多相關資料。悲哀的是,感覺網上都是千篇一律的。說64系統需要在syswow64文件夾下註冊控制項,有的說同時需要也在syst...
  • 客戶端發送請求->IIS, UrlRouting模塊對比URL, 預設如果該URL能對應到實體文件則退出MVC管道把控制權交還給IIS.如果RegisterRoutes中的路由規則對比成功預設情況下交給MvcRouteHandler(IRouteHandler)處理,IRouteHandler的作用...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...