国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

首頁 Java Java基礎(chǔ) java中的不重複的集合有哪些

java中的不重複的集合有哪些

Dec 27, 2019 am 09:47 AM
java 集合

java中的不重複的集合有哪些

Java集合類別存放在 java.util 套件中,是用來存放物件的容器。下面我們來看看java中不重複的集合。

Set:典型實(shí)作HashSet()是一個(gè)無序,不可重複的集合

1、Set hashSet = new HashSet();

# ①、HashSet:不能保證元素的順序;不可重複;不是線程安全的;集合元素可以為NULL;

②、其底層其實(shí)是一個(gè)數(shù)組,存在的意義是加快查詢速度。我們知道在一般的數(shù)組中,元素在數(shù)組中的索引位置是隨機(jī)的,元素的取值和元素的位置之間不存在確定的關(guān)係,因此,在數(shù)組中查找特定的值時(shí),需要把查找值和一系列的元素進(jìn)行比較,此時(shí)的查詢效率取決於查找過程中比較的次數(shù)。而 HashSet 集合底層陣列的索引和值有一個(gè)確定的關(guān)係:index=hash(value),那麼只要呼叫這個(gè)公式,就能快速的找到元素或索引。

③、對於 HashSet: 如果兩個(gè)物件透過 equals() 方法傳回 true,這兩個(gè)物件的 hashCode 值也應(yīng)該相同。

2、Set linkedHashSet = new LinkedHashSet();

①、不可以重複,有序

因?yàn)榈讓訏裼缅€錶和哈希表的演算法。鍊錶保證元素的新增順序,雜湊表保證元素的唯一性

3、Set treeSet = new TreeSet();

TreeSet:有序;不可重複,底層使用紅黑樹演算法,擅長於範(fàn)圍查詢。

*? 如果使用 TreeSet() 無參數(shù)的建構(gòu)器建立 TreeSet 物件, 則要求放入其中的元素的類別必須實(shí)作 Comparable 介面所以, 在其中不能放入 null 元素。

以上三個(gè)Set 介面的實(shí)作類別比較:

共通點(diǎn):

1、都不允許元素重複

2、都不是執(zhí)行緒安全的類,解決方法:Set set = Collections.synchronizedSet(set 物件)

不同點(diǎn):

HashSet:不保證元素的新增順序,底層採用哈希表演算法,查詢效率高。判斷兩個(gè)元素是否相等,equals() 方法傳回 true,hashCode() 值相等。即要求存入HashSet 中的元素要覆寫equals() 方法和hashCode()方法

LinkedHashSet:HashSet 的子類,底層採用了哈希表演算法以及鍊錶演算法,既保證了元素的新增順序,也保證了查詢效率。但是整體效能要低於 HashSet    

TreeSet:不保證元素的新增順序,但是會(huì)對集合中的元素進(jìn)行排序。底層採用紅-黑樹演算法(樹結(jié)構(gòu)比較適合範(fàn)圍查詢)

Map:key-value 的鍵值對,key 不允許重複,value 可以

#1、嚴(yán)格來說Map 並不是一個(gè)集合,而是兩個(gè)集合之間的映射關(guān)係。

2、這兩個(gè)集合沒每一條資料通過映射關(guān)係,我們可以看成是一條資料。即 Entry(key,value)。 Map 可以看成是由多個(gè) Entry 組成。

3、因?yàn)?Map 集合即沒有實(shí)作於 Collection 接口,也沒有實(shí)作 Iterable 接口,所以不能對 Map 集合進(jìn)行 for-each 遍歷。

更多java知識請關(guān)注java基礎(chǔ)教學(xué)欄。

以上是java中的不重複的集合有哪些的詳細(xì)內(nèi)容。更多資訊請關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願(yuàn)投稿,版權(quán)歸原作者所有。本站不承擔(dān)相應(yīng)的法律責(zé)任。如發(fā)現(xiàn)涉嫌抄襲或侵權(quán)的內(nèi)容,請聯(lián)絡(luò)admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅(qū)動(dòng)的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強(qiáng)大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Laravel 教程
1600
29
PHP教程
1502
276
如何使用JDBC處理Java的交易? 如何使用JDBC處理Java的交易? Aug 02, 2025 pm 12:29 PM

要正確處理JDBC事務(wù),必須先關(guān)閉自動(dòng)提交模式,再執(zhí)行多個(gè)操作,最後根據(jù)結(jié)果提交或回滾;1.調(diào)用conn.setAutoCommit(false)以開始事務(wù);2.執(zhí)行多個(gè)SQL操作,如INSERT和UPDATE;3.若所有操作成功則調(diào)用conn.commit(),若發(fā)生異常則調(diào)用conn.rollback()確保數(shù)據(jù)一致性;同時(shí)應(yīng)使用try-with-resources管理資源,妥善處理異常並關(guān)閉連接,避免連接洩漏;此外建議使用連接池、設(shè)置保存點(diǎn)實(shí)現(xiàn)部分回滾,並保持事務(wù)盡可能短以提升性能。

如何使用Java的日曆? 如何使用Java的日曆? Aug 02, 2025 am 02:38 AM

使用java.time包中的類替代舊的Date和Calendar類;2.通過LocalDate、LocalDateTime和LocalTime獲取當(dāng)前日期時(shí)間;3.使用of()方法創(chuàng)建特定日期時(shí)間;4.利用plus/minus方法不可變地增減時(shí)間;5.使用ZonedDateTime和ZoneId處理時(shí)區(qū);6.通過DateTimeFormatter格式化和解析日期字符串;7.必要時(shí)通過Instant與舊日期類型兼容;現(xiàn)代Java中日期處理應(yīng)優(yōu)先使用java.timeAPI,它提供了清晰、不可變且線

比較Java框架:Spring Boot vs Quarkus vs Micronaut 比較Java框架:Spring Boot vs Quarkus vs Micronaut Aug 04, 2025 pm 12:48 PM

前形式攝取,quarkusandmicronautleaddueTocile timeProcessingandGraalvSupport,withquarkusoftenpernperforminglightbetterine nosserless notelless centarios.2。

垃圾收集如何在Java工作? 垃圾收集如何在Java工作? Aug 02, 2025 pm 01:55 PM

Java的垃圾回收(GC)是自動(dòng)管理內(nèi)存的機(jī)制,通過回收不可達(dá)對象釋放堆內(nèi)存,減少內(nèi)存洩漏風(fēng)險(xiǎn)。 1.GC從根對象(如棧變量、活動(dòng)線程、靜態(tài)字段等)出發(fā)判斷對象可達(dá)性,無法到達(dá)的對像被標(biāo)記為垃圾。 2.基於標(biāo)記-清除算法,標(biāo)記所有可達(dá)對象,清除未標(biāo)記對象。 3.採用分代收集策略:新生代(Eden、S0、S1)頻繁執(zhí)行MinorGC;老年代執(zhí)行較少但耗時(shí)較長的MajorGC;Metaspace存儲(chǔ)類元數(shù)據(jù)。 4.JVM提供多種GC器:SerialGC適用於小型應(yīng)用;ParallelGC提升吞吐量;CMS降

了解網(wǎng)絡(luò)端口和防火牆 了解網(wǎng)絡(luò)端口和防火牆 Aug 01, 2025 am 06:40 AM

NetworkPortSandFireWallsworkTogetHertoEnableCommunication whereSeringSecurity.1.NetWorkPortSareVirtualendPointSnumbered0-655 35,with-Well-with-Newonportslike80(HTTP),443(https),22(SSH)和25(smtp)sindiessingspefificservices.2.portsoperateervertcp(可靠,c

以身作則,解釋說明 以身作則,解釋說明 Aug 02, 2025 am 06:26 AM

defer用於在函數(shù)返回前執(zhí)行指定操作,如清理資源;參數(shù)在defer時(shí)立即求值,函數(shù)按後進(jìn)先出(LIFO)順序執(zhí)行;1.多個(gè)defer按聲明逆序執(zhí)行;2.常用於文件關(guān)閉等安全清理;3.可修改命名返回值;4.即使發(fā)生panic也會(huì)執(zhí)行,適合用於recover;5.避免在循環(huán)中濫用defer,防止資源洩漏;正確使用可提升代碼安全性和可讀性。

Java並發(fā)公用事業(yè):執(zhí)行人員服務(wù)和叉/加入 Java並發(fā)公用事業(yè):執(zhí)行人員服務(wù)和叉/加入 Aug 03, 2025 am 01:54 AM

ExecutorService適用於獨(dú)立任務(wù)的異步執(zhí)行,如I/O操作或定時(shí)任務(wù),使用線程池管理並發(fā),通過submit提交Runnable或Callable任務(wù),並用Future獲取結(jié)果,需注意無界隊(duì)列風(fēng)險(xiǎn)和顯式關(guān)閉線程池;2.Fork/Join框架專為可拆分的CPU密集型任務(wù)設(shè)計(jì),基於分治法和工作竊取算法,通過RecursiveTask或RecursiveAction實(shí)現(xiàn)任務(wù)遞歸拆分,由ForkJoinPool調(diào)度執(zhí)行,適合大數(shù)組求和、排序等場景,需合理設(shè)置拆分閾值避免開銷;3.選擇依據(jù):獨(dú)立任

比較Java構(gòu)建工具:Maven vs. Gradle 比較Java構(gòu)建工具:Maven vs. Gradle Aug 03, 2025 pm 01:36 PM

Gradleisthebetterchoiceformostnewprojectsduetoitssuperiorflexibility,performance,andmoderntoolingsupport.1.Gradle’sGroovy/KotlinDSLismoreconciseandexpressivethanMaven’sverboseXML.2.GradleoutperformsMaveninbuildspeedwithincrementalcompilation,buildcac

See all articles