欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java中的HashSet集合解析

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

HashSet集合解析

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

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

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

初始化

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

存取、刪除操作

HashSet 中的基本操作是使用 HashMap 的操作實(shí)現(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 對(duì)象的實(shí)例,是為 HashMap 的 value 虛設(shè)的。盡管 HashMap 的 value 可以為 null,但是這里不適用 null 的原因很簡(jiǎn)單,因?yàn)槭褂?null ,則在 add 和 remove 操作時(shí)會(huì)產(chǎn)生歧義,無(wú)法區(qū)分 HashMap 中是否已經(jīng)存在過(guò)舊的值。

迭代器

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

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

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

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

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

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

相關(guān)文章

  • SpringBoot之HttpWebServiceMessageSenderBuilder用法詳解

    SpringBoot之HttpWebServiceMessageSenderBuilder用法詳解

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

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

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

    IDEA中安裝testng插件過(guò)程

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

    IDEA-SpringBoot項(xiàng)目Debug啟動(dòng)不了(卡住不動(dòng))的原因分析

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

    Java使用DateTimeFormatter格式化輸入的日期時(shí)間

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

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

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

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

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

    Java分布式鎖由淺入深介紹

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

    使用java對(duì)一副撲克牌建模

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

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

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

最新評(píng)論