Java Set系列集合詳解:HashSet、LinkedHashSet、TreeSet底層原理與使用場景

Java Set系列集合詳解:HashSet、LinkedHashSet、TreeSet底層原理與使用場景


一、Set系列集合概述

1. 核心特點

  • 無序性:存取順序不一致(LinkedHashSet除外)。
  • 唯一性:元素不重復。
  • 無索引:無法通過索引直接訪問元素,不能使用普通for循環遍歷。

2. 常見實現類

實現類特點底層數據結構
HashSet無序、唯一、無索引哈希表(數組+鏈表/紅黑樹)
LinkedHashSet有序(存取順序一致)、唯一哈希表+雙向鏈表
TreeSet可排序(自然或自定義)、唯一紅黑樹

二、Set接口常用方法

Set繼承自Collection接口,常用方法如下:

方法說明
boolean add(E e)添加元素,成功返回true
void clear()清空集合
boolean remove(E e)刪除指定元素
`boolean contains(Object)判斷是否包含元素
int size()返回集合元素個數

三、各實現類詳解

1. HashSet

底層原理
  • JDK8前:數組 + 鏈表。
  • JDK8后:數組 + 鏈表 + 紅黑樹(鏈表長度≥8且數組長度≥64時觸發轉換)。
  • 哈希值計算:通過重寫hashCode()equals()保證元素唯一性。
擴容機制
  • 默認初始容量:16。
  • 加載因子:0.75(當元素數量達到容量的75%時觸發擴容)。
代碼示例
Set<String> set = new HashSet<>();
set.add("A");
set.add("A"); // 添加失敗
System.out.println(set); // 輸出無序,如 [A, B]

2. LinkedHashSet

核心特點
  • 繼承自HashSet,通過雙向鏈表維護插入順序。
  • 性能略低于HashSet,但遍歷效率更高。
代碼示例
LinkedHashSet<String> linkedSet = new LinkedHashSet<>();
linkedSet.add("B");
linkedSet.add("A");
System.out.println(linkedSet); // 輸出順序固定為 [B, A]

3. TreeSet

排序規則
  • 自然排序:元素需實現Comparable接口,重寫compareTo()
  • 比較器排序:創建TreeSet時傳入Comparator自定義規則。
代碼示例
// 自然排序(按年齡升序)
TreeSet<Student> treeSet = new TreeSet<>();
treeSet.add(new Student("Tom", 20));
treeSet.add(new Student("Alice", 18));
// 輸出按年齡排序:Alice(18) → Tom(20)

四、補充知識點

1. 線程安全性

  • HashSetTreeSetLinkedHashSet非線程安全
  • 解決方案:使用Collections.synchronizedSet()包裝。
Set<String> syncSet = Collections.synchronizedSet(new HashSet<>());

2. 哈希沖突解決策略

  • 鏈地址法(HashSet采用):沖突元素以鏈表形式存儲。
  • 開放尋址法:線性探測或二次探測。

3. 紅黑樹簡介

  • 一種自平衡二叉查找樹,保證插入、刪除、查找的時間復雜度為O(log n)
  • 特性:節點顏色交替、根節點為黑、葉子節點為黑、任意路徑黑節點數相同。

4. 性能對比

操作HashSetLinkedHashSetTreeSet
插入O(1)O(1)O(log n)
刪除O(1)O(1)O(log n)
查詢O(1)O(1)O(log n)
有序性插入順序自然/自定義

五、應用場景總結

場景推薦集合
去重且無需順序HashSet
去重且保留插入順序LinkedHashSet
去重且需排序TreeSet
高頻查詢HashSet
需要線程安全Collections.synchronizedSet()

六、常見面試題

  1. HashSet如何保證元素唯一?
    通過hashCode()equals()方法:先比較哈希值,再通過equals判斷內容是否相同。

  2. TreeSet兩種排序方式如何選擇?

    • 默認使用自然排序(需實現Comparable)。
    • 若類無法修改或需多規則排序,使用Comparator
  3. HashSet和HashMap的關系?
    HashSet底層基于HashMap實現,元素存儲為HashMap的鍵(值固定為PRESENT占位對象)。


關注博主,獲取更多Java集合框架深度解析!

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/81151.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/81151.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/81151.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

解決 CentOS 7 鏡像源無法訪問的問題

在國內使用 CentOS 系統時&#xff0c;經常會遇到鏡像源無法訪問或者下載速度慢的問題。尤其是默認的 CentOS 鏡像源通常是國外的&#xff0c;如果你的網絡環境無法直接訪問國外服務器&#xff0c;就會出現無法下載包的情況。本文將介紹如何修改 CentOS 7 的鏡像源為國內鏡像源…

云計算與大數據進階 | 26、解鎖云架構核心:深度解析可擴展數據庫的5大策略與挑戰(上)

在云應用/服務的 5 層架構里&#xff0c;數據庫服務層穩坐第 4 把交椅&#xff0c;堪稱其中的 “硬核擔當”。它的復雜程度常常讓人望而生畏&#xff0c;不少人都將它視為整個架構中的 “終極挑戰”。 不過&#xff0c;也有人覺得可擴展存儲系統才是最難啃的 “硬骨頭”&#…

Linux——UDP/TCP協議理論

1. UDP協議 1.1 UDP協議格式 系統內的UDP協議結構體&#xff1a; 注1&#xff1a;UDP協議的報頭大小是確定的&#xff0c;為8字節 注2&#xff1a;可以通過報頭中&#xff0c;UDP長度將UDP協議的報頭和有效載荷分離&#xff0c;有效載荷將存儲到接收緩沖區中等待上層解析。 注…

考研復習全年規劃

25考研以330分成功上岸。 備考期間&#xff0c;我深知學習規劃的重要性&#xff0c;為大家精心整理了一份初試備考時間線任務規劃&#xff0c;希望能為正在備考的同學們提供參考。如果你對如何規劃學習路線仍感迷茫&#xff0c;不妨參考這份時間表&#xff0c;合理分配時間&…

PhpStudy | PhpStudy 環境配置 —— PhpStudy 目錄結構 環境變量配置 · Windows 篇

&#x1f31f;想了解這個工具的其它相關筆記&#xff1f;看看這個&#xff1a;[網安工具] 服務器環境配置工具 —— PhpStudy 使用手冊 在前面的章節中&#xff0c;筆者詳細介紹了如何在 Windows 和 Linux 系統中安裝 PhpStudy&#xff0c;但可能會有崽崽在安裝完成后發現依舊…

DDS(數據分發服務) 和 P2P(點對點網絡) 的詳細對比

1. 核心特性對比 維度 DDS P2P 實時性 微秒級延遲&#xff0c;支持硬實時&#xff08;如自動駕駛&#xff09; 毫秒至秒級&#xff0c;依賴網絡環境&#xff08;如文件傳輸&#xff09; 架構 去中心化發布/訂閱模型&#xff0c;節點自主發現 完全去中心化&#xff0c;節…

java中XML的使用

文章目錄 什么是XML特點XML作用XML的編寫語法基本語法特殊字符編寫 約束XML的書寫格式DTD文檔schema文檔屬性命名空間XML命名空間的作用 解析XML的方法??DOM解析XMLDOM介紹DOM解析包&#xff1a;org.w3c.dom常用接口DOM解析包的使用保存XML文件添加DOM節點修改/刪除DOM節點 S…

Spring Boot異步任務失效的8大原因及解決方案

Spring Boot異步任務失效的8大原因及解決方案 摘要:在使用Spring Boot的@Async實現異步任務時,你是否遇到過異步不生效的問題?本文總結了8種常見的異步失效場景,并提供對應的解決方案,幫助你徹底解決異步任務失效的難題。 一、異步失效的常見場景 1. 未啟用異步支持 ? …

QT6 源(104)篇一:閱讀與注釋QAction,其是窗體菜單欄與工具欄里的菜單項,先給出屬性測試,再給出成員函數測試,最后給出信號函數的學習于舉例測試

&#xff08;1&#xff09; &#xff08;2&#xff09; &#xff08;3&#xff09;接著給出成員函數測試 &#xff1a; &#xff08;4&#xff09; 給個信號函數的舉例 &#xff1a; &#xff08;5&#xff09; 謝謝

visual studio生成動態庫DLL

visual studio生成動態庫DLL 創建動態庫工程 注意 #include “pch.h” 要放在上面 完成后點擊生成 創建一個控制臺項目 設置項目附加目錄為剛才創建的動態庫工程Dll1&#xff1a; 配置附加庫目錄&#xff1a; 配置動態庫的導入庫&#xff08;.lib&#xff09;&#xff1a;鏈…

matlab多智能體網絡一致性研究

一個基于連續時間多智能體系統&#xff08;Multi-Agent Systems, MAS&#xff09;的一階一致性協議的MATLAB仿真代碼&#xff0c;包含網絡拓撲建模、一致性協議設計和收斂性分析。代碼支持固定拓撲和時變拓撲&#xff0c;適用于學術研究。 1. 基礎模型與代碼框架 (1) 網絡拓撲…

【omnet++】omnet++6.0.3中調用python

版本&#xff1a; omnet 6.0.3 Ubuntu 20.04.6 LTS omnet的installguide中對ubuntu版本是有要求的&#xff0c;找到對應版本下載即可 先安裝omnet再安裝anaconda omnet 6.0.3安裝 別在網上找教程了&#xff0c;官方的installguide手冊是最好的。按照手冊安裝一些依賴包后 so…

【C++】 —— 筆試刷題day_29

一、排序子序列 題目解析 一個數組的連續子序列&#xff0c;如果這個子序列是非遞增或者非遞減的&#xff1b;這個連續的子序列就是排序子序列。 現在給定一個數組&#xff0c;然后然我們判斷這個子序列可以劃分成多少個排序子序列。 例如&#xff1a;1 2 3 2 2 1 可以劃分成 …

UE RPG游戲開發練手 第二十七課 普通攻擊2

UE RPG游戲開發練手 第二十七課 普通攻擊2 1. 創建普通攻擊的蒙太奇動畫 2.打開4個蒙太奇動畫&#xff0c;修改插槽為FullBody,修改動畫速度 3.編輯動畫藍圖&#xff0c;插入FullBody插槽讓普通攻擊動畫得以播放 4. 編輯GA_LightAttack技能藍圖

MySQL——日志

undo log(回滾日志)&#xff1a;引擎層生成的日志&#xff0c;實現了事務的原子性&#xff0c;用于事務回滾和MVCC。redo log(重做日志)&#xff1a;引擎層生成的日志&#xff0c;實現了事務的持久性&#xff0c;用于非正常關閉的數據恢復。bin log(歸檔日志)&#xff1a;Serve…

QML 動畫控制、順序動畫與并行動畫

目錄 引言相關閱讀基礎屬性說明工程結構示例代碼解析示例1&#xff1a;手動控制動畫&#xff08;ControlledAnimation.qml&#xff09;示例2&#xff1a;順序動畫&#xff08;SequentialAnimationDemo.qml&#xff09;示例3&#xff1a;并行動畫&#xff08;ParallelAnimationD…

PowerShell 實現 conda 懶加載

問題 執行命令conda init powershell會在 profile.ps1中添加conda初始化的命令。 即使用戶不需要用到conda&#xff0c;也會初始化conda環境&#xff0c;拖慢PowerShell的啟動速度。 解決方案 本文展示了如何實現conda的懶加載&#xff0c;默認不加載conda環境&#xff0c;只…

R語言學習--Day03--數據清洗技巧

在一般情況下&#xff0c;我們都是在數據分析的需求前提下去選擇使用R語言。而實際上&#xff0c;數據分析里&#xff0c;百分之八十的工作&#xff0c;都是在數據清洗。并不只是我們平時會提到的異常值處理或者是整合格式&#xff0c;更多會涉及到將各種各樣的數據整合&#x…

谷歌地圖代理 | 使用 HTML 和矢量模式 API 更輕松地創建 Web 地圖

在過去的一年里&#xff0c;谷歌對 Maps JavaScript API 進行了兩項重要更新&#xff0c;以便更輕松地采用我們最新、最好的地圖&#xff1a;HTML 地圖和矢量模式 API。今天谷歌地圖亞太區最大代理商之一的 Cloud Ace云一 為大家介紹一下更新的具體內容。 聯系我們 - Cloud Ac…

WL-G4048 Multi-Port PCIe 4.0 Switch

系列文章目錄 文章目錄 系列文章目錄《WL-G4048 Multi-Port PCIe 4.0 Switch數據手冊》總結一、芯片介紹二、芯片規格介紹&#xff08;一&#xff09;功能指標&#xff08;二&#xff09;管理調試和監控&#xff08;三&#xff09;參考時鐘&#xff08;四&#xff09;系統復位 …