亚洲 国产精品 日韩-亚洲 激情-亚洲 欧美 91-亚洲 欧美 成人日韩-青青青草视频在线观看-青青青草影院

千鋒教育-做有情懷、有良心、有品質的職業教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > Set集合都有哪些特性

Set集合都有哪些特性

來源:千鋒教育
發布人:zyh
時間: 2023-06-12 16:29:00 1686558540

  全文大約【4000】字,不說廢話,只講可以讓你學到技術、明白原理的純干貨!本文帶有豐富的案例及配圖視頻,讓你更好地理解和運用文中的技術概念,并可以給你帶來具有足夠啟迪的思考......

  一. Set集合簡介

1684751678786.image

  1.Set定義

  Set是Java的一種集合,繼承自Collection接口,主要有兩個常用的實現類HashSet類和TreeSet類。它沒有固定的大小限制,可以動態地添加和刪除元素。并且Set集合中的元素都是唯一的,不會有重復的元素,即使是null值也只能有一個。另外Set集合是無序的,不能記住元素的添加順序,因為沒有索引值,所以Set集合中的對象不會按特定的方式排序,它只是簡單地把對象放到集合中。

  從特性上來看,Set相當于是一個只存儲key、不存儲value的Map。我們可以把Set想象成是一個”特殊的Map“,這個Map只有key卻沒有value,所以我們可以用Set去除重復的元素。另外由于放入Set的元素和Map的key類似,需要正確地實現equals()和hashCode()方法,否則該元素就無法正確地放入Set。

  2.Set特性

  與其他集合不同,Set集合具有自己的一些特性:

  ● Set集合中的元素都是唯一的,不允許有重復值,且最多只允許包含一個null元素;

  ● Set集合中的元素沒有順序,我們無法通過索引來訪問元素,但TreeSet是有序的;

  ● Set集合沒有固定的大小限制,可以動態地添加和刪除元素;

  ● Set集合提供了高效的元素查找和判斷方法。

  3.Set常用方法

  Set集合給我們提供了一系列常用的方法,用于添加、刪除、查找、遍歷和獲取集合元素等操作,下面是Set集合中常用方法的實現過程。

  3.1 添加元素

  我們可以使用add()方法進行元素的添加。 

public boolean add(E e)

  該方法用于向Set集合添加元素,如果元素已經存在,則不會添加;如果添加成功,則返回true,否則返回false。該方法的示例代碼如下:  

Set<String> set = new HashSet<>(); 
set.add("hello word");
set.add("java");
set.add("iOS");
System.out.println(set);

  3.2 刪除元素

  我們可以使用remove()方法進行元素的刪除。  

public boolean remove(Object o)

  該方法用于從Set集合中刪除指定的元素。如果元素存在且刪除成功,則返回true,否則返回false。該方法的示例代碼如下:  

Set<String> set = new HashSet<>(); 
set.add("hello word");
set.add("java");
set.remove("java");
System.out.println(set); // 輸出結果為:[壹小編]

  3.3 判斷元素

  我們可以使用contains()方法進行元素的判斷。 

public boolean contains(Object o)

  該方法用于判斷Set集合中是否包含指定的元素。如果元素存在,則返回true,否則返回false。該方法的示例代碼如下:  

Set<String> set = new HashSet<>(); 
set.add("hello word");
set.add("java");
System.out.println(set.contains("java")); // 輸出結果為:true
System.out.println(set.contains("orange")); // 輸出結果為:false

  3.4 獲取元素數量

  我們可以使用size()方法判斷集合的數量。  

public int size()

  該方法的使用示例代碼如下: 

Set<String> set = new HashSet<>(); 
set.add("hello word");
set.add("java");
System.out.println(set.size()); // 輸出結果為:2

  二. HashSet集合

  1.簡介

  在Java的集合框架中,HashSet是一種非常常用的集合類型,它實現了Set接口,并繼承了AbstractSet抽象類。HashSet集合的底層實現是一個哈希表,它使用哈希算法來存儲和管理集合中的元素。HashSet集合中的元素沒有順序,且不允許重復。

  如果我們想使用HashSet集合,一般要使用如下兩個構造方法創建出HashSet對象:

  ● HashSet():構造一個新的空的Set集合對象;

  ● HashSet(Collection c):構造一個包含指定Collection集合元素的新Set集合。"< >"中的extends,表示這個Collection中的元素必須繼承自HashSet的父類,該部分限定了Collection元素的類型。

  2.HashSet特性

  HashSet作為Set集合的具體子類,具有以下特點:

  ● HashSet的底層是基于HashMap來實現的;

  ● HashSet中的元素是唯一的,內部不允許有重復的元素;

  ● 無序,不會記錄插入元素的順序,所以不能保證元素的排列順序,獲取順序可能與添加順序不同;

  ● HashSet集合沒有固定的大小限制,可以動態地添加和刪除元素;

  ● HashSet集合中的元素最多可以有一個null值;

  ● HashSet不是線程安全的,默認線程不同步,如果有多個線程同時訪問或修改同一個HashSet,必須通過代碼來保證同步操作。

  3.去重原理

  從底層實現來看,HashSet的底層其實就是一個值為Object的HashMap,如下圖所示:

1684751821084.image

1684751816321.image

  所以HashSet其實就是按照Hash算法來實現元素的查找和存儲的,具有很好的存取和查找性能。當我們向HashSet集合中存入一個元素時,HashSet會調用該對象的hashCode()方法來得到該對象的hashCode值,然后根據該hashCode值決定該對象在HashSet中的存儲位置。此時如果有兩個元素通過equals()方法進行比較,返回的結果為true,但它們的hashCode卻不相等,HashSet也會把它們存儲在不同的位置,我們依然可以添加成功。也就是說,如果兩個對象的hashCode值相等,且通過equals()方法比較返回的結果也為true, HashSet集合才會認為兩個元素相等。

  4.使用案例

  我們通過一個簡單的案例,來看看HashSet的基本用法。 

import java.util.HashSet;

public class Demo11 {

public static void main(String[] args) {
//創建HashSet集合
HashSet<String> set = new HashSet<String>();
set.add("java");
//重復元素無法被添加進去
set.add("java");
System.out.println(set);

//集合遍歷
Iterator<String> it = set.iterator();
while (it.hasNext()) {
//輸出Set集合中的每個元素
System.out.println("值="+it.next());
}
}
}

  在上面的代碼中,我們通過HashSet的構造方法創建了一個Set集合對象,并將幾個元素對象存儲到了這個Set集合中。然后我們使用HashSet類中的iterator()方法獲取一個Iterator對象,并調用hasNext()方法遍歷集合元素,再使用next()方法獲取到下一個數據元素。但是HashSet輸出的元素是無序的,輸出時既不是添加元素的順序,也不是String排序的順序,在不同版本的JDK中,這個順序可能也是不同的。另外因為Set是不可重復的,如果我們向Set集合中添加了兩個相同的元素,則后添加的會覆蓋前面添加的元素,所以Set集合中不會出現相同的元素。

  三. TreeSet集合

  1.簡介

  TreeSet是一種很常用的集合類型,它實現了Set和SortedSet接口,并且繼承自AbstractSet抽象類。TreeSet集合中的元素也是唯一的,不允許重復。TreeSet集合的底層基于紅黑樹,可以使用自然排序或指定的比較器對集合中的元素進行排序。該類具有如下特點:

  ● TreeSet集合中的元素是唯一的,不允許重復。

  ● TreeSet集合中的元素是有序的,因為實現了SortedSet接口,具有字典順序,可以通過迭代器按照升序或降序遍歷。

  ● TreeSet集合沒有固定的大小限制,可以動態地添加和刪除元素。

Set集合都有哪些特性

  ● TreeSet集合提供了高效的元素查找和判斷功能。

  另外,SortedSet接口是Set接口的子接口,能夠對集合進行自然排序,因此TreeSet類默認情況下就是自然排序(升序)的。但TreeSet只能對實現了Comparable接口的類對象進行排序,所以我們使用TreeSet集合存儲對象時,該對象必須要實現Comparable接口。這是因為Comparable接口中有一個compareTo(Object o)方法,可以比較兩個對象的大小。例如,a.compareTo(b),如果 a 和 b 相等,則該方法會返回 0;如果 a 大于 b,則該方法返回大于 0 的正值;如果 a 小于 b,則該方法返回小于 0 的負值。

  2.常用方法

  除了Set類中通用的方法之外,TreeSet類還有如下幾個特有的方法:

1684751904085.image

  因為TreeSet中的元素是有序的,所以增加了訪問第一個、前一個、后一個、最后一個元素的相關方法,并提供了3個從 TreeSet中截取子TreeSet的方法。

  3.去重原理

  當TreeSet集合在保存對象元素時,集合對象必須實現Comparable接口,并重寫compareTo方法,該方法有如下兩個作用:

  ● 排序: 返回值大于0表示升序,返回值小于0表示降序;

  ● 去重(返回值為0):TreeSet認為返回0,表示兩個對象是相同的對象。

  所以我們利用TreeSet實現去重的原理就是:如果compareTo()方法的返回值為0,則認為是相同的對象;如果compareTo()方法的返回大于0,則是升序排序;如果小于0,則是降序排序。

  4.使用案例

  接下來我們再通過一個案例來看看TreeSet的用法。

  4.1 編寫Person類

  首先我們設計一個Person類,該類要實現Comparable接口。當TreeSet集合在保存對象元素時,集合中添加的元素對象必須實現Comparable接口,并重寫compareTo方法。如果沒有實現Comparable接口,那么創建TreeSet時必須傳入一個Comparator對象。  

/**
* 實現Comparable接口,并重新compareTo()方法
*/
public class Person implements Comparable<Person>{

private String username;
private String password;

public Person() {
}

public Person(String username, String password) {
super();
this.username = username;
this.password = password;
}

@Override
public String toString() {
return "User [username=" + username + ", password=" + password + "]";
}

//重寫compareTo()方法,對Person對象進行比較
@Override
public int compareTo(Person o) {
if(!this.username.equals(o.username)) {
//根據姓名及長度進行比較
return this.username.length() - o.username.length();
}else {
//根據密碼進行比較
if(this.password.equals(o.password)) {
return 0;
}else {
//比較姓名的長度
return this.username.length() - o.username.length();
}
}
}
}

  4.2 測試TreeSet排序功能

  然后我們往TreeSet集合中添加若干個對象元素進行排序測試,代碼如下: 

import java.util.TreeSet;

public class Demo12 {

public static void main(String[] args) {
//TreeSet的去重原理
TreeSet<Person> set = new TreeSet<Person>();
set.add(new Person("admin","123"));
set.add(new Person("yyg","bb"));
set.add(new Person("jack","123"));
set.add(new Person("rose123","123"));
set.add(new Person("admin","123"));
set.add(new Person("xksss6","abc"));

//如果兩個對象的用戶名和密碼都相等,則認為是兩個相同的對象,且按照名字長度升序存放
for (Person person : set) {
System.out.println(person);
}
}
}

  我們在遍歷TreeSet時,輸出的元素是有序的,這個順序是元素的排序順序。但是我們在使用TreeSet進行自然排序時,只能向 TreeSet 集合中添加相同數據類型的對象,否則會拋出 ClassCastException異常。如果向 TreeSet集合中添加了一個 Double類型的對象,則后面只能添加 Double對象,不能再添加其他類型的對象,例如 String對象等。

  四. 結語

  至此,小編就帶各位把Set集合及其子類學習完了,現在你學會了嗎?本文的重點內容如下所示:

  ● Set用于存儲不重復的元素集合;

  ● 放入HashSet的元素,與作為HashMap的key要求相同;

  ● 放入TreeSet的元素,與作為TreeMap的Key要求相同;

  ● 利用Set可以去除重復元素;

  ● 遍歷SortedSet時,可以按照元素的排序順序進行遍歷,我們也可以自定義排序算法;

tags: Set集合
聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
10年以上業內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT
18禁黄网站禁片免费观看自慰| 无码无套少妇毛少18PXX| 色一情一乱一伦一区二区三欧美| 玩弄朋友娇妻呻吟交换电影| 亚洲国产成人精品无码区在线| 又爽又黄又无遮挡网站| 宝贝我不想带小雨伞了| 国产乱妇乱子视频在播放| 久久AV无码AV高潮AV| 欧美电影在线观看| 四十路の五十路熟女豊満| 亚洲国产精品尤物YW在线观看 | 欧美激欧美啪啪片SM| 少妇夜夜春夜夜爽试看视频| 亚洲乱码av无码一区二区三区| 2018国产精华国产精品| 国产成人无码3000部| 久久精品国产亚洲AV蜜臀色欲| 欧洲熟妇色XXXXⅩ| 亚洲AV成人片色在线观看蜜臀| 又大又长粗又爽又黄少妇毛片| 大粗鳮巴久久久久久久久| 国产真人无码作爱免费视频| 男人扒开女人下部添高潮的视频| 四川小少妇BBAABBAA| 一本一道AV中文字幕无码| 成人免费A级毛片天天看| 精品国产乱码久久久久APP下载 | 久久综合九色综合欧美98| 日韩一区二区在线视频| 亚洲日韩亚洲另类激情文学| YYYY1111111午夜少妇| 互换人妻ⅩXXBBBB| 日本理论片和搜子同居的日子| 亚洲高清毛片一区二区| WWWらだ在线天堂中文在线| 国精产品W灬源码1688伊| 欧美熟妇另类久久久久久多毛 | 性欧美人与ZOZOXXXX视频| 日韩成人一区二区三区在线观看| 亚洲AV丰满熟妇在线播放| 中文字幕免费不卡二区| 国产欧美另类精品久久久| 男女做AJ视频免费的网站| 亚精区在二线三线区别99| AV天堂永久资源网| 韩国亚洲精品a在线无码| 日本AⅤ精品一区二区三区日| 亚洲乱人伦中文字幕无码| 成人免费无码不卡毛片| 久久久久久久波多野结衣高潮| 少妇人妻综合久久中文字幕| 中文字幕乱码亚洲无线码| 国产欧美久久久久久精品一区二区| 欧美xxxxx视频| 亚洲精品成人久久AV| 粉嫩粉嫩的18在线免免费观看| 亂倫近親相姦中文字幕| 亚洲AV无码AV日韩AV网站| 成人免费视频一区二区| 美女黄网站免费福利视频| 午夜爽爽爽男女免费观看影院| WWWXXX国产| 裸体欣赏ⅤIDE0SPH0TO| 亚洲AV无码成人精品国产| 岛国精品一区免费视频在线观看| 乱码视频午夜在线观看| 亚洲爆乳精品无码一区二区| 丰满的熟妇人妻中文字幕久久 | 精品国产AⅤ一区二区三区V视界 | 日本免费黄色网址| 重生后我抛弃了负心公主| 极品少妇XXXX精品少妇小说| 舌头伸进去添的我好爽高潮欧美| 7777精品久久久大香线蕉| 精品亚洲成A人无码成A在线观看 | 日韩一区在线视频| 50熟妇的长奶头满足了我| 久久精品成人无码观看免费| 小东西才几天没做喷的到处都是| 成人免费无遮挡无码黄漫视频 | 视频一区欧美日韩| SUNTEK中老年妈妈| 免费午夜爽爽爽WWW视频十八禁| 亚洲国产精品成人久久| 国产精品免费精品自在线观看| 日产乱码一二三区别免费麻豆| 50岁毛多熟女一区二区三区| 久久久久亚洲AV成人网址| 亚洲成无码电影在线观看| 国产精品爽爽ⅴa在线观看| 色翁荡息又大又硬又粗视频| А√天堂8资源官网在线BT种子| 免费A级毛片无码A∨奶水在线 | 久久精品人人做人人爽电影蜜月| 亚洲AV无码成人精品网站漏男 | 无码人妻出轨与黑人中文字幕 | 色欲AⅤ亚洲情无码AV| 阿娇被躁120分钟视频| 女被男狂揉吃奶胸60分钟视频| 野花视频在线手机免费观看| 好男人官网在线观看免费播放| 无码专区3D动漫精品免费| 国产成人精品视频网站| 四虎永久免费地址WW41.6| 东北少妇大叫高潮XXXⅩ| 日本丰满熟妇BBXBBXHD| 巴西FREE性VIDEO极品| 欧美日韩精品人妻二区| 99国产精品永久免费视频| 免费播放片高清在线视频| 中文无码日韩欧免费视频| 老师办公室被吃奶好爽在线观看| 野花日本大全免费观看3中文版| 精品一区二区三区在线成人| 亚洲乱亚洲乱少妇无码| 精品人妻VA出轨中文字幕| 亚洲精品久久久久无码AV片软件| 娇小美女被黑壮汉C到喷水| 亚洲成A人片在线观看无码不卡| 国产真人无码作爱视频免费| 亚洲AV无码AV吞精久久| 国内精品久久久久精免费| 亚洲VA中文字幕无码一二三区| 国产一卡2卡3卡4卡网站免费| 亚洲 国产 韩国 欧美 在线| 孩交精品XXXX视频视频| 亚洲国产成人久久一区二区三区| 护士奶头又白又大又好摸| 亚洲欧美成人一区二区三区| 久久久久精品精品6精品精品| 一本久久精品一区二区| 蜜臀av无码少妇一区二区三区| 1000部啪啪未满十八勿入| 欧美人与性动交α欧美精品| 扒开双腿疯狂进出爽爽爽动态图| 日韩AV毛片无码免费| 国产成人精品无码一区二区老年人| 无码AⅤ精品一区二区三区浪潮| 国产精品无码久久久久| 亚洲AV永久无码精品九之| 久久精品国产精品亚洲毛片| 中国性猛交ⅩXXX免费看| 欧美无砖专区一中文字| 粉嫩AV一区二区夜夜嗨| 无码一区二区三区视频| 激情综合色五月丁香六月欧美| 一夲道中文字幕AV高清片 | 好男人好资源影视在线| 亚洲一线二线三线品牌精华液| 免费高清A级毛片在线播放| 波多野结衣乳喷高潮视频| 天天躁夜夜躁狠狠夜夜| 好爽…又高潮了毛片喷水| 野花日本免费完整版高清版8 | 天天摸日日摸狠狠添| 国精产品自偷自偷综合下载| 一边摸一边做爽的视频17国产| 内谢XXXXX8老| 多毛丰满日本熟妇| 亚洲AV无码久久| 乱码人妻一区二区三区| 被男人吃奶很爽的毛片| 挽起裙子迈开腿坐下去的图片高清| 狠狠躁夜夜躁人人爽天天天天97 | 欧美丰满熟妇XXXX性PPX人| 厨房里我扒了岳的内裤| 小雪被老汉玩遍各种方式电影| 久久久精品波多野结衣| ZLJZLJZLJZLJ亚洲| 午夜理论片YY6080影院| 久久综合九色综合欧美| 成人性生交大片免费看| 亚洲Av无码成人黄网站在线| 蜜臀亚洲AV无码精品国产午夜. | 色综合久久精品亚洲国产消防| 国产亚洲午夜高清国产拍精品| 曰本无码人妻丰满熟妇啪| 人妻AV中文字幕一区二区三区| 国产免费AV片在线观看| 一区二区三区午夜无码视频| 日韩A∨精品日韩在线观看| 国内精品免费久久久久电影院97| 中文字幕无码成人免费视频 | 亚洲色一色噜一噜噜噜| 欧美黑人巨大手机在线观看| 国产精品嫩草影院AV| 永久免费无码国产| 少妇短裙公车被直接进入| 久久高清内射无套| 波多野结衣高清一区二区三区| 小诗的公交车日记免费读| 免费无码作爱视频| 国产伦精品一区二区三区妓女| 中国蓝CHINABLUE| 无码18在线网站成人网站| 乱人伦XXXX国语对白| 国产精华液一线二线三线 | 成年免费手机毛片免费看无码| 亚洲VA韩国VA欧美VA|