第四章 CopyOnWriteArraySet源碼解析

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

註:在看這篇文章之前,如果對CopyOnWriteArrayList底層不清楚的話,建議先去看看CopyOnWriteArrayList源碼解析。http://www.cnblogs.com/java-zhao/p/5121944.html1、對於CopyOnWriteArraySet需要掌握以下幾...


註:在看這篇文章之前,如果對CopyOnWriteArrayList底層不清楚的話,建議先去看看CopyOnWriteArrayList源碼解析。

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

1、對於CopyOnWriteArraySet需要掌握以下幾點

  • 創建:CopyOnWriteArraySet()
  • 添加元素:即add(E)方法
  • 刪除對象:即remove(E)方法
  • 遍歷所有對象:即iterator(),在實際中更常用的是增強型的for迴圈去做遍歷

註:

  • CopyOnWriteArraySet(不可添加重覆元素)底層是CopyOnWriteArrayList(可添加重覆元素)
  • Set集合沒有按索引直接獲取或修改或添加或刪除的方法(eg.get(int index),add(int index,E e),set(int index,E e),remove(int index))

2、創建

public CopyOnWriteArraySet()

使用方法:

Set<String> strSet = new CopyOnWriteArraySet<String>();

源代碼:

    private final CopyOnWriteArrayList<E> al;//底層數據結構

    public CopyOnWriteArraySet() {
        al = new CopyOnWriteArrayList<E>();
    }
View Code

註意點:

  • CopyOnWriteArraySet底層就是一個CopyOnWriteArrayList

 

3、添加元素

public boolean add(E e)

使用方法:

strSet.add("hello")

源代碼:

    /**
     * 迴圈遍歷舊數組,若有與e相同的值,return false
     * 若沒有,向最後插值
     */
    public boolean add(E e) {
        return al.addIfAbsent(e);
    }
View Code

CopyOnWriteArrayList的addIfAbsent(E e)

    public boolean addIfAbsent(E e) {
        final ReentrantLock lock = this.lock;
        lock.lock();
        try {
            Object[] elements = getArray();
            int len = elements.length;
            Object[] newElements = new Object[len + 1];
            for (int i = 0; i < len; ++i) {
                if (eq(e, elements[i]))//先迴圈一遍看看有沒有與要插入的值相同的值
                    return false; // 如果有,直接返回
                else
                    newElements[i] = elements[i];
            }
            newElements[len] = e;//如果沒有,就賦值
            setArray(newElements);
            return true;
        } finally {
            lock.unlock();
        }
    }
View Code

註:這一塊兒的源代碼很簡單,只要你看了CopyOnWriteArrayList源碼解析中的add方法就能看懂

註意點:

  • CopyOnWriteArraySet每次add都要遍曆數組,性能要低於CopyOnWriteArrayList

 

4、刪除元素

public boolean remove(Object o)

使用方法:

strSet.remove("hello")

源代碼:

    /**
     * 調用CopyOnWriteArrayList的remove(Object o)方法
     */
    public boolean remove(Object o) {
        return al.remove(o);
    }
View Code

 

5、遍歷所有元素

 public Iterator<E> iterator()

使用方法:見上一章《CopyOnWriteArrayList源碼解析》

源代碼:

    /**
     * 調用CopyOnWriteArrayList的iterator()
     */
    public Iterator<E> iterator() {
        return al.iterator();
    }
View Code

剩餘的源代碼見上一章《CopyOnWriteArrayList源碼解析》

 

總結:

  • CopyOnWriteArraySet底層就是一個CopyOnWriteArrayList
  • CopyOnWriteArraySet在add元素的時候要遍歷一遍數組,從而起到不添加重覆元素的作用,但是由於要遍曆數組,效率也會低於CopyOnWriteArrayList的add
  • Set集合沒有按索引直接獲取或修改或添加或刪除的方法(eg.get(int index),add(int index,E e),set(int index,E e),remove(int index))

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

-Advertisement-
Play Games
更多相關文章
  • 一、collection系列:1、counter計數器如果counter(dict)是對字典的一個補充,如果counter(list)則是對列表的補充,初步測試對字典的值進行排序。############################################################...
  • 首先要安裝這個庫,可以使用pip安裝,那麼我們要首先安裝pip去https://bootstrap.pypa.io/get-pip.py下載get-pip.py,然後運行python get-pip.py安裝後添加系統path變數c:/Python27/Scripts然後安裝image庫,因為我系統...
  • golang interface記憶體佈局
  • 複製當前行:ctrl+alt+↓刪除當前行:Ctrl+d行註釋:Ctrl+/快註釋(先選中要註釋的代碼):Ctrl+shift+/提示助手(方便函數等補全):alt+/代碼格式化:Ctrl+shift+F最牛逼的快捷鍵(可以顯示所有的快捷鍵):Ctrl+shift+l
  • 前言 其實cloudera已經做了這個事了,只是把kafka的包和cdh的parcel包分離了,只要我們把分離開的kafka的服務描述jar包和服務parcel包下載了,就可以實現完美集成了。具體實現的簡要步驟可參照cloudera官網提供的文檔:http://www.cloudera.com...
  • Spring Boot 項目(參考1) 提供了一個類似ASP.NET MVC的預設模板一樣的標準樣板,直接集成了一系列的組件並使用了預設的配置。使用Spring Boot 不會降低學習成本,甚至增加了學習成本,但顯著降低了使用成本並提高了開發效率。如果沒有Spring基礎不建議直接上手。1.基礎項目...
  • 三層菜單,根據用戶所選數字,進入子菜單。一級一級呈現。 1 menu = { 2 'Beijing': { 3 "ChaoYang": { 4 "CBD": ['CICC', 'CCTV'], 5 "JinRongJie": [...
  • 在AN65209中 有一些應用筆記集錦,希望對大家有用。當然AN65209這篇應用筆記很重要,希望大家一定要看!!!一定要看!!!!
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...