Java HashSet

Java HashSet

Java 集合框架

HashSet 基於 HashMap 來實現的,是一個不允許有重複元素的集合。

HashSet 允許有 null 值。

HashSet 是無序的,即不會記錄插入的順序。

HashSet 不是執行緒安全的, 如果多個執行緒嘗試同時修改 HashSet,則最終結果是不確定的。 您必須在多執行緒訪問時顯式同步對 HashSet 的併發訪問。

HashSet 實現了 Set 介面。

HashSet 中的元素實際上是物件,一些常見的基本型別可以使用它的包裝類。

基本型別對應的包裝類表如下:

基本型別引用型別
booleanBoolean
byteByte
shortShort
intInteger
longLong
floatFloat
doubleDouble
charCharacter

HashSet 類位於 java.util 包中,使用前需要引入它,語法格式如下:

import java.util.HashSet; // 引入 HashSet 類

以下例項我們建立一個 HashSet 物件 sites,用於儲存字串元素:

HashSet<String> sites = new HashSet<String>();

新增元素

HashSet 類提供類很多有用的方法,新增元素可以使用 add() 方法:

例項

// 引入 HashSet 類      
import java.util.HashSet;

public class itread01Test {
    public static void main(String[] args) {
    HashSet<String> sites = new HashSet<String>();
        sites.add("Google");
        sites.add("itread01");
        sites.add("Taobao");
        sites.add("Zhihu");
        sites.add("itread01");  // 重複的元素不會被新增
        System.out.println(sites);
    }
}

執行以上程式碼,輸出結果如下:

[Google, itread01, Zhihu, Taobao]

在上面的例項中,itread01 被添加了兩次,它在集合中也只會出現一次,因為集合中的每個元素都必須是唯一的。

判斷元素是否存在

我們可以使用 contains() 方法來判斷元素是否存在於集合當中:

例項

// 引入 HashSet 類      
import java.util.HashSet;

public class itread01Test {
    public static void main(String[] args) {
    HashSet<String> sites = new HashSet<String>();
        sites.add("Google");
        sites.add("itread01");
        sites.add("Taobao");
        sites.add("Zhihu");
        sites.add("itread01");  // 重複的元素不會被新增
        System.out.println(sites.contains("Taobao"));
    }
}

執行以上程式碼,輸出結果如下:

true

刪除元素

我們可以使用 remove() 方法來刪除集合中的元素:

例項

// 引入 HashSet 類      
import java.util.HashSet;

public class itread01Test {
    public static void main(String[] args) {
    HashSet<String> sites = new HashSet<String>();
        sites.add("Google");
        sites.add("itread01");
        sites.add("Taobao");
        sites.add("Zhihu");
        sites.add("itread01");     // 重複的元素不會被新增
        sites.remove("Taobao");  // 刪除元素,刪除成功返回 true,否則為 false
        System.out.println(sites);
    }
}

執行以上程式碼,輸出結果如下:

[Google, itread01, Zhihu]

刪除集合中所有元素可以使用 clear 方法:

例項

// 引入 HashSet 類      
import java.util.HashSet;

public class itread01Test {
    public static void main(String[] args) {
    HashSet<String> sites = new HashSet<String>();
        sites.add("Google");
        sites.add("itread01");
        sites.add("Taobao");
        sites.add("Zhihu");
        sites.add("itread01");     // 重複的元素不會被新增
        sites.clear();  
        System.out.println(sites);
    }
}

執行以上程式碼,輸出結果如下:

[]

計算大小

如果要計算 HashSet 中的元素數量可以使用 size() 方法:

例項

// 引入 HashSet 類      
import java.util.HashSet;

public class itread01Test {
    public static void main(String[] args) {
    HashSet<String> sites = new HashSet<String>();
        sites.add("Google");
        sites.add("itread01");
        sites.add("Taobao");
        sites.add("Zhihu");
        sites.add("itread01");     // 重複的元素不會被新增
        System.out.println(sites.size());  
    }
}

執行以上程式碼,輸出結果如下:

4

迭代 HashSet

可以使用 for-each 來迭代 HashSet 中的元素。

例項

// 引入 HashSet 類      
import java.util.HashSet;

public class itread01Test {
    public static void main(String[] args) {
    HashSet<String> sites = new HashSet<String>();
        sites.add("Google");
        sites.add("itread01");
        sites.add("Taobao");
        sites.add("Zhihu");
        sites.add("itread01");     // 重複的元素不會被新增
        for (String i : sites) {
            System.out.println(i);
        }
    }
}

執行以上程式碼,輸出結果如下:

Google
itread01
Zhihu
Taobao

更多 API 方法可以檢視:https://www.itread01.com/manual/jdk11api/java.base/java/util/HashSet.html

Java 集合框架