Java中的set集合是什么意思
引言
在前面的內(nèi)容中,我們先是一一介紹了Collection集合中都有哪些種類的集合,并且詳細地講解了List集合中的相關(guān)知識,那么今天我們來詳細地講解一下Collection集合中的另外一個分支——Set系列集合。最后還是希望這一篇篇的文章能夠?qū)δ阍诩现械膶W(xué)習、Java中的學(xué)習起到一定的幫助作用,好了,閑話不多說直接步入正題吧。
概念
Set系類集合特點:
- 無序:存取順序不一致
- 不重復(fù):可以去除重復(fù)
- 無索引:沒有帶索引的方法,所以不能使用普通for循環(huán)遍歷,也不能通過索引來獲取元素
Set集合實現(xiàn)類特點:
HashSet:無序、不重復(fù)、無索引
LinkedHashSet:有序、不重復(fù)、無索引
TreeSet:排序、不重復(fù)、無索引
Set集合的功能上基本上與Collection的API一致。
HashSet集合
HashSet集合:
Set<String> set = new HashSet<>(); set.add("石原里美"); set.add("石原里美"); set.add("工藤靜香"); set.add("朱茵"); System.out.println(set); set.remove("朱茵"); System.out.println(set);
輸出結(jié)果:
通過上述代碼與運行結(jié)果,我們可以清晰地看出,HashSet集合無序、不重復(fù)的特性;
結(jié)合上述圖片所示,可以看出HashSet集合是無法通過get()方法的索引獲取數(shù)據(jù)的,并且在刪除集合中的數(shù)據(jù)的時候,也只能通過定向的對數(shù)據(jù)進行刪除。
LinkedHashSet集合:
LinkedHashSet集合:
Set<String> set = new LinkedHashSet<>(); set.add("石原里美"); set.add("石原里美"); set.add("工藤靜香"); set.add("朱茵"); System.out.println(set); set.remove("朱茵"); System.out.println(set);
輸出結(jié)果:
通過上述代碼與輸出結(jié)果做對比,即可看出無序與有序之間的區(qū)別,前者是會將傳入的數(shù)據(jù)順序打亂,而后者則是仍然按照輸入數(shù)據(jù)的順序存儲數(shù)據(jù),因此輸出的時候是有序狀態(tài)。
TreeSet集合:
TreeSet集合:
Set<Integer> set = new TreeSet<>(); set.add(13); set.add(23); set.add(23); set.add(11); System.out.println(set); set.remove(23); System.out.println(set);
輸出結(jié)果:
通過上述代碼和輸出結(jié)果我們便可以通過字面意思去理解為什么TreeSet的特點是排序了,即將存儲的數(shù)據(jù)按照Java默認的排序方式進行排序。
然而此時若存儲自定義如People對象,TreeSet無法直接排序,會出現(xiàn)報錯的情況!
//People類: public class People{ private String name; private int age; private String classroom; public People(){ } public People(String name, int age, String classroom) { this.name = name; this.age = age; this.classroom = classroom; } public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } public String getClassroom() { return classroom; } public void setClassroom(String classroom) { this.classroom = classroom; } @Override public String toString() { return "People{" + "name='" + name + '\'' + ", age=" + age + ", classroom='" + classroom + '\'' + '}'; } } //main方法: public static void main(String[] args) { Set<People> p = new TreeSet<>(); p.add(new People("張三",19,"智能")); p.add(new People("李四",18,"數(shù)據(jù)庫")); p.add(new People("王五",20,"滲透")); System.out.println(p); }
若想解決該問題,我們就需要為TreeSet集合自定義存儲類型,現(xiàn)有兩種方式可以解決該問題:一種是自定義類實現(xiàn)Comparable接口并重寫里面的compareTo方法指定規(guī)則;另一種則是集合自帶比較器對象進行規(guī)則定義。
方式一:自定義類實現(xiàn)Comparable接口重寫里面的compareTo方法指定比較規(guī)則(多余無關(guān)緊要的代碼在此不再贅述了,只展示重要的那部分代碼)
//改變的第一個地方:實現(xiàn)Comparable類 public class People implements Comparable<People> { //改變的第二個地方:重寫Comparable類中的compareTo方法 @Override public int compareTo(People o) { return this.age-o.age; } }
輸出結(jié)果(根據(jù)年齡進行比較):
在重寫的方法中,return后面的代碼決定了該對象將要根據(jù)什么準則進行比較,比較規(guī)則如下:
- 如果認為第一個元素大于第二個元素返回正整數(shù)即可
- 如果認為第一個元素小于第二個元素返回負整數(shù)即可
- 如果認為第一個元素等于第二個元素返回0即可,此時Treeset集合只會保留一個元素,認為兩者重復(fù)
方式二:集合自帶比較器對象進行規(guī)則定義
Set<People> p = new TreeSet<>(new Comparator<People>() { @Override public int compare(People o1, People o2) { return o1.getAge()-o2.getAge(); } });
在原來的基礎(chǔ)之上對集合的創(chuàng)建作出改變,并且其比較準則與前面的定義方法類似,相對前面的方式,這種方式會更加方便快捷一些。在此,我們也可以回顧一些前面所學(xué)到的知識“Lambda表達式”,對給代碼塊進行化簡。
Set<People> p = new TreeSet<>((o1, o2) -> o1.getAge()-o2.getAge());
如果沒有學(xué)習過Lambda表達式,或者說是對Lambda表達式的知識不清晰,那么可以可以看Java中的lambda表達式如何理解——精簡這篇文章的講解,或許會對你有所幫助的。
實戰(zhàn)場景
- 元素可以重復(fù)、又有索引、索引查詢速度快
使用ArrayList集合,基于數(shù)組
- 元素可以重復(fù)、又有索引、增刪首尾操作快
使用LinkedList集合,基于鏈表
- 增刪查改快,但是元素不重復(fù)、無序、無索引
使用HashSet集合,基于哈希表
- 增刪查改快,但是元素不重復(fù)、有序、無索引
使用LinkedHashSet集合,基于哈希表和雙鏈表
- 需要對對象進行排序
使用TreeSet集合,基于紅黑樹,后續(xù)也可以使用List集合實現(xiàn)
到此這篇關(guān)于Java中的set集合是什么意思的文章就介紹到這了,更多相關(guān)javaset集合內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java數(shù)據(jù)結(jié)構(gòu)之常見排序算法(下)
這篇文章主要介紹了Java數(shù)據(jù)結(jié)構(gòu)之常見排序算法(下),與之相對有(上),想了解的朋友可以去本網(wǎng)站掃搜,在這兩篇文章里涵蓋關(guān)于八大排序算法的所有內(nèi)容,需要的朋友可以參考下2023-01-01Java Comparable和Comparator對比詳解
這篇文章主要介紹了Java Comparable和Comparator對比詳解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友可以參考下2019-11-11詳解Jenkins 實現(xiàn)Gitlab事件自動觸發(fā)Jenkins構(gòu)建及釘釘消息推送
這篇文章主要介紹了Jenkins 實現(xiàn)Gitlab事件自動觸發(fā)Jenkins構(gòu)建及釘釘消息推送,應(yīng)該會對大家學(xué)習Jenkins有所啟發(fā)2021-04-04Spring?boot2.0?實現(xiàn)日志集成的方法(2)
這篇文章主要介紹了Spring?boot2.0?實現(xiàn)日志集成的方法,上一章講解了spring?boot日志簡單集成,這篇我們將日志進行分類,常規(guī)日志、異常日志、監(jiān)控日志等,需要將日志輸出到不同的文件,具體內(nèi)容需要的小伙伴可以參考一下2022-04-04