亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Java中的HashSet集合解析

 更新時間:2023年11月02日 10:28:48   作者:荊軻刺秦  
這篇文章主要介紹了Java中的HashSet集合解析,HashSet 實現(xiàn) Set 接口,內(nèi)部維護一個 HashMap 實例,它不能保證集合迭代的順序,也不能保證順序不變,HashSet 允許 null 元素,需要的朋友可以參考下

HashSet集合解析

HashSet 實現(xiàn) Set 接口,內(nèi)部維護一個 HashMap 實例。它不能保證集合迭代的順序,也不能保證順序不變。HashSet 允許 null 元素。

該類對于基本操作,例如 add、remove、contains 和 size提供了常數(shù)時間的性能,迭代器的性能與 HashSet 實例的大小加上內(nèi)部維護的 HashMap 的“容量”(即桶的數(shù)量)之和有關(guān)。所以,如果迭代性能很重要的話,并不建議把初始化容量設(shè)置的太大或者把負載因子設(shè)置的太小(HashMap 一文中有講解)。

該集合并沒有被同步,所以在有多個線程并發(fā)訪問 HashSet 時,并且至少有一個集合修改了這個 Set ,它必須要額外的同步。這通常是對自然封裝了該集合的某個對象進行同步來完成。比如 Collections的 synchronizedSet 方法返回的就是一個這樣的對象。

初始化

初始化則主要是負責初始化內(nèi)部維護的 HashMap,初始化策略遵循 HashMap 的初始化策略,默認大小為 16 ,負載因子為 0.75。

存取、刪除操作

HashSet 中的基本操作是使用 HashMap 的操作實現(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();
    }

PRESENT 是 Object 對象的實例,是為 HashMap 的 value 虛設(shè)的。盡管 HashMap 的 value 可以為 null,但是這里不適用 null 的原因很簡單,因為使用 null ,則在 add 和 remove 操作時會產(chǎn)生歧義,無法區(qū)分 HashMap 中是否已經(jīng)存在過舊的值。

迭代器

HashSet 的迭代器仍然是快速失敗的,快速失敗很好理解,在并發(fā)情況下,存在線程修改容器,那么其它正在迭代容器的線程將盡最大可能拋出 ConcurrentModificationException。從字面意思來看,依賴該異常來進行編程并不是很好的選擇,我們可能不能夠及時得到這個異常,僅僅將它用來檢查 bug 還是可行的。

	public Iterator<E> iterator() {
        return map.keySet().iterator();
    }

可以發(fā)現(xiàn),HashSet 的迭代器直接使用的 HashMap 的 keySet 方法返回的其內(nèi)部實現(xiàn)的 KeySet 對象實例的迭代器。

前文有提到關(guān)于迭代器性能的問題,這是與 HashMap 特殊的底層數(shù)據(jù)結(jié)構(gòu)有關(guān)(數(shù)組+鏈表或者數(shù)組+紅黑樹),無論是哪種,遍歷都是先從數(shù)組中的第一個元素(即“桶”)開始,接著遍歷桶中的元素,直到整個數(shù)組遍歷完成。

所以,其性能和數(shù)組的大小加上元素數(shù)量之和有關(guān)。

到此這篇關(guān)于Java中的HashSet集合解析的文章就介紹到這了,更多相關(guān)HashSet集合解析內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • SpringBoot之HttpWebServiceMessageSenderBuilder用法詳解

    SpringBoot之HttpWebServiceMessageSenderBuilder用法詳解

    這篇文章主要介紹了SpringBoot之HttpWebServiceMessageSenderBuilder用法,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2025-04-04
  • Java數(shù)組隊列及環(huán)形數(shù)組隊列超詳細講解

    Java數(shù)組隊列及環(huán)形數(shù)組隊列超詳細講解

    隊列是一個有序列表,可以用數(shù)組和鏈表來實現(xiàn),隊列有一個原則。即:先存入隊列的數(shù)據(jù)要先取出,后存入的要后取出,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧
    2022-09-09
  • IDEA中安裝testng插件過程

    IDEA中安裝testng插件過程

    這篇文章主要介紹了IDEA中安裝testng插件過程,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-06-06
  • IDEA-SpringBoot項目Debug啟動不了(卡住不動)的原因分析

    IDEA-SpringBoot項目Debug啟動不了(卡住不動)的原因分析

    這篇文章主要介紹了IDEA-SpringBoot項目Debug啟動不了(卡住不動)的原因分析,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • Java使用DateTimeFormatter格式化輸入的日期時間

    Java使用DateTimeFormatter格式化輸入的日期時間

    這篇文章主要介紹了Java使用DateTimeFormatter格式化輸入的日期時間,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-01-01
  • 基于Java解決華為機試實現(xiàn)密碼截取?

    基于Java解決華為機試實現(xiàn)密碼截取?

    這篇文章主要介紹了基于Java解決華為機試實現(xiàn)密碼截取,文章圍繞主題相關(guān)資料展開詳細內(nèi)容,具有一的參考價值,需要的小伙伴可以參考一下,希望對你有所幫助
    2022-02-02
  • Java設(shè)計模式筆記之抽象工廠代碼示例

    Java設(shè)計模式筆記之抽象工廠代碼示例

    這篇文章主要介紹了Java設(shè)計模式筆記之抽象工廠代碼示例,見解獨到,代碼詳細,具有一定參考價值,需要的朋友可以了解下。
    2017-10-10
  • Java分布式鎖由淺入深介紹

    Java分布式鎖由淺入深介紹

    這篇文章主要介紹了Java分布式鎖,數(shù)據(jù)庫實現(xiàn)分布式鎖方式比較多,如悲觀鎖(查詢時增加for?update)、樂觀鎖(通過version字段)、增加一個表記錄鎖信息等。因為依賴于數(shù)據(jù)庫,比較好理解,但是也存在一些問題
    2023-03-03
  • 使用java對一副撲克牌建模

    使用java對一副撲克牌建模

    這篇文章主要為大家詳細介紹了如何使用java對一副撲克牌建模,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-04-04
  • Java使用wait/notify實現(xiàn)線程間通信下篇

    Java使用wait/notify實現(xiàn)線程間通信下篇

    wait()和notify()是直接隸屬于Object類,也就是說所有對象都擁有這一對方法,下面這篇文章主要給大家介紹了關(guān)于使用wait/notify實現(xiàn)線程間通信的相關(guān)資料,需要的朋友可以參考下
    2022-12-12

最新評論