国产精品色哟哟_男男激情3p互攻_色偷偷影院_和女同学厕所做了四次

當(dāng)前位置: 首頁 / 技術(shù)干貨 / 正文
Set接口簡介

2022-12-15

元素 hashset student 集合

  Set接口簡介

  Set接口和List接口一樣,同樣繼承自Collection接口,它與Collection接口中的方法基本一致,并沒有對Collection接口進行功能上的擴充,只是比Collection接口更加嚴(yán)格了。與List接口不同的是,Set接口中元素?zé)o序,并且都會以某種規(guī)則保證存入的元素不出現(xiàn)重復(fù)。

  Set接口主要有兩個實現(xiàn)類,分別是HashSet和TreeSet。其中,HashSet是根據(jù)對象的哈希值來確定元素在集合中的存儲位置,具有良好的存取和查找性能。TreeSet則是以二叉樹的方式來存儲元素,它可以實現(xiàn)對集合中的元素進行排序。

  HashSet集合

  HashSet是Set接口的一個實現(xiàn)類,它所存儲的元素是不可重復(fù)的,并且元素都是無序的。接下來通過一個案例演示HashSet集合的用法。  

Java
import java.util.HashSet;
import java.util.Iterator;

public class Example07 {
    public static void main(String[] args) {
        HashSet set = new HashSet(); // 創(chuàng)建HashSet集合
        set.add("張三"); // 向該Set集合中添加字符串
        set.add("李四");
        set.add("王五");
        set.add("李四"); // 向該Set集合中添加重復(fù)元素
        Iterator it = set.iterator(); // 獲取Iterator對象
        while (it.hasNext()) { // 通過while循環(huán),判斷集合中是否有元素
            Object obj = it.next(); // 如果有元素,就通過迭代器的next()方法獲取元素
            System.out.println(obj);
        }
    }
}

  從打印結(jié)果可以看出,取出元素的順序與添加元素的順序并不一致,并且重復(fù)存入的字符串對象“李四”被去除了,只添加了一次。

  HashSet集合之所以能確保不出現(xiàn)重復(fù)的元素,是因為它在存入元素時做了很多工作。當(dāng)調(diào)用HashSet集合的add()方法存入元素時,首先調(diào)用當(dāng)前存入對象的hashCode()方法獲得對象的哈希值,然后根據(jù)對象的哈希值計算出一個存儲位置。如果該位置上沒有元素,則直接將元素存入,如果該位置上有元素存在,則會調(diào)用equals()方法讓當(dāng)前存入的元素依次和該位置上的元素進行比較,如果返回的結(jié)果為false就將該元素存入集合,返回的結(jié)果為true則說明有重復(fù)元素,就將該元素舍棄。HashSet存儲元素的流程如下圖所示。

  根據(jù)前面的分析不難看出,當(dāng)向集合中存入元素時,為了保證HashSet正常工作,要求在存入對象時,重寫Object類中的hashCode()和equals()方法。在上述案例中將字符串存入HashSet時,String類已經(jīng)重寫了Object類中的hashCode()和equals()方法。但是如果將自定義的Student對象存入HashSet,結(jié)果又如何呢?

  接下來通過一個案例演示向HashSet存儲字符串。 

Java
import java.util.HashSet;

class Student {
    String id;
    String name;

          // 創(chuàng)建構(gòu)造方法
    public Student(String id, String name) {
        this.id = id;
        this.name = name;
    }

          // 重寫toString()方法
    @Override
    public String toString() {
        return id + ":" + name;
    }
}
public class Example08 {
    public static void main(String[] args) {
        HashSet hs = new HashSet(); // 創(chuàng)建HashSet集合
        Student stu1 = new Student("1", "張三"); // 創(chuàng)建Student對象
        Student stu2 = new Student("2", "李四");
        Student stu3 = new Student("2", "李四");
        hs.add(stu1);
        hs.add(stu2);
        hs.add(stu3);
        System.out.println(hs);
    }
}

  在上述代碼的運行結(jié)果中,出現(xiàn)了兩個相同的學(xué)生信息“2:李四”,這樣的學(xué)生信息應(yīng)該被視為重復(fù)元素,不允許同時出現(xiàn)在HashSet集合中。之所以沒有去掉這樣的重復(fù)元素,是因為在定義Student類時沒有重寫hashCode()和equals()方法。

  接下來對Student類進行改寫,假設(shè)id相同的學(xué)生就是同一個學(xué)生,改寫后代碼見下。  

Java
import java.util.HashSet;
import java.util.Objects;

class Student {
    String id;
    String name;

    // 創(chuàng)建構(gòu)造方法
    public Student(String id, String name) {
        this.id = id;
        this.name = name;
    }

    // 重寫toString()方法
    @Override
    public String toString() {
        return id + ":" + name;
    }

    // 重寫hashCode方法
    @Override
    public int hashCode() {
        return id.hashCode(); // 返回id屬性的哈希值
    }

    // 重寫equals方法
    @Override
    public boolean equals(Object o) {
        // 判斷是否是同一個對象,如果是,直接返回true
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;
        // 判斷對象是否為Student類型
        if (!(o instanceof Student)) return false;
        // 將對象強轉(zhuǎn)為Student類型
        Student student = (Student) o;
        // return (id == student.id) || (id != null && id.equals(student.id));
        return Objects.equals(id, student.id);
    }
}

public class Example09 {
    public static void main(String[] args) {
        HashSet hs = new HashSet(); // 創(chuàng)建HashSet集合
        Student stu1 = new Student("1", "張三"); // 創(chuàng)建Student對象
        Student stu2 = new Student("2", "李四");
        Student stu3 = new Student("2", "李四");
        hs.add(stu1);
        hs.add(stu2);
        hs.add(stu3);
        System.out.println(hs);
    }
}

  在上述代碼中,Student類重寫了Object類的hashCode()和equals()方法。在hashCode()方法中返回id屬性的哈希值,在equals()方法中比較對象的id屬性是否相等,并返回結(jié)果。當(dāng)調(diào)用HashSet集合的add()方法添加stu3對象時,發(fā)現(xiàn)它的哈希值與stu2對象相同,而且id.equals(student.id)返回true,HashSet集合認為兩個對象相同,因此重復(fù)的Student對象被成功去除了。

  HashSet集合存儲的元素是無序的,如果想讓元素的存取順序一致,可以使用Java中提供的LinkedHashSet類,LinkedHashSet類是HashSet的子類,與LinkedList一樣,它也使用雙向鏈表來維護內(nèi)部元素的關(guān)系。

  接下來通過一個案例學(xué)習(xí)LinkedHashSet類的用法。 

Java
import java.util.Iterator;
import java.util.LinkedHashSet;

public class Example10 {
    public static void main(String[] args) {
        LinkedHashSet set = new LinkedHashSet();
        set.add("張三"); // 向該Set集合中添加字符串
        set.add("李四");
        set.add("王五");
        Iterator it = set.iterator(); // 獲取Iterator對象
        while (it.hasNext()) { // 通過while循環(huán),判斷集合中是否有元素
            Object obj = it.next();
            System.out.println(obj);
        }
    }
}

  通過運行結(jié)果可以看出,元素迭代出來的順序和存入的順序是一致的。

分享: 更多

上一篇:foreach循環(huán)介紹

下一篇:TreeSet集合

好程序員公眾號

  • · 剖析行業(yè)發(fā)展趨勢
  • · 匯聚企業(yè)項目源碼

好程序員開班動態(tài)

More+
  • HTML5大前端 <高端班>

    開班時間:2021-04-12(深圳)

    開班盛況

    開班時間:2021-05-17(北京)

    開班盛況
  • 大數(shù)據(jù)+人工智能 <高端班>

    開班時間:2021-03-22(杭州)

    開班盛況

    開班時間:2021-04-26(北京)

    開班盛況
  • JavaEE分布式開發(fā) <高端班>

    開班時間:2021-05-10(北京)

    開班盛況

    開班時間:2021-02-22(北京)

    開班盛況
  • Python人工智能+數(shù)據(jù)分析 <高端班>

    開班時間:2021-07-12(北京)

    預(yù)約報名

    開班時間:2020-09-21(上海)

    開班盛況
  • 云計算開發(fā) <高端班>

    開班時間:2021-07-12(北京)

    預(yù)約報名

    開班時間:2019-07-22(北京)

    開班盛況
IT培訓(xùn)IT培訓(xùn)
在線咨詢
IT培訓(xùn)IT培訓(xùn)
試聽
IT培訓(xùn)IT培訓(xùn)
入學(xué)教程
IT培訓(xùn)IT培訓(xùn)
立即報名
IT培訓(xùn)

Copyright 2011-2023 北京千鋒互聯(lián)科技有限公司 .All Right 京ICP備12003911號-5 京公網(wǎng)安備 11010802035720號