国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

Java 集合 Set

verano / 893人閱讀

摘要:當復制集合中的所有元素來創建新的集合時,要求集合中的所有元素必須是同一個枚舉類的枚舉值各實現類的性能分析的性能總比好,特別是最常用的添加查詢元素等操作。因為需要額外的紅黑樹算法來維護集合元素的次序。在創建時進行,以防對集合的意外非同步訪問

HashSet

大多時候使用Set集合時就是使用HashSet實現類。HashSet按Hash算法來存儲集合中的元素,因此具有很好的存取和查找性能

HashSet具有以下特點

不能保證元素的排列順序,順序可能與添加順序不同,順序也有可能發生變化

HashSet不是同步的,如果多個線程同時訪問一個HashSet,假設有兩個或兩個以上線程同時修改了HashSet集合時,則必須通過代碼來保證其同步

集合元素值可以是null

HashSet會調用該對象的hashCode()方法來得到該對象的hashCode()值,然后根據該hashCode()值決定該對象在HashSet中的存儲位置;HashSet集合判斷兩個元素相等的標準是兩個對象通過equals()方法比較相等,并且兩個對象的hashCode()方法返回值也相等

hash(也被翻譯為哈希、散列)算法的功能:
它能保證快速查找被檢索的對象,hash算法的價值在于速度。當需要查詢集合中某個元素時,hash算法可以根據該元素的hashCode值計算出該元素的存儲位置,從而快速定位該元素。

為什么不直接使用數組、還需要使用HashSet?
因為數組元素的索引是連續的,而且數組的長度是固定的、無法自由增加數組的長度。而HashSet采用每個元素的hashCode值來計算其存儲位置,從而可以自由增加HashSet的長度,并可以根據元素的HashCode值來訪問元素。因此,當從HashSet中訪問元素時,HashSet先計算該元素的hashCode值(調用該對象的hashCode()方法的返回值),然后直接到該hashCode值對應的位置去取出該元素——這就是HashSet速度很快的原因

HashSet中每個能存儲元素的“槽位”(slot)通常稱為“桶”(bucket)

hashCode()方法的基本重寫規則

在程序運行過程中,同一個對象多次調用hashCode()方法應該返回相同的值

當兩個對象通過equals()方法比較返回true時,這兩個對象的hashCode()方法應該返回相等的值

對象中用作equals()方法比較標準的實例變量,都應該用于計算hashCode()值

hashCode()方法的基本重寫步驟

把對象內每個有意義的實例變量(即每個參與equals()方法比較標準的實例變量)計算出一個Int類型的hashCode值

用第一步計算出來的多個hashCode值組合計算出一個hashCode值返回

LinkedHashSet類

LinkedHashSet集合根據元素的hashCode值來決定元素的存儲位置,同時使用鏈表維護元素的次序,這樣使得元素看起來是以插入的順序保存的。當遍歷LinkedHashSet集合里的元素時,LinkedHashSet將會按元素的添加順序來訪問集合里的元素

LinkedHashSet需要維護元素的插入順序,因此性能略低于HashSet的性能,但在迭代訪問Set里的全部元素時將有很好的性能,因為它以鏈表來維護內部順序

雖然LinkedHashSet使用了鏈表記錄集合元素的添加順序,但LinkedHashSet依然是HashSet,因此不允許集合元素重復

TreeSet類

TreeSet是SortedSet接口的實現類,可以確保集合元素處于排序狀態。根據元素實際值的大小進行排序

TreeSet的額外方法

Comparator comparator():如果TreeSet采用了定制排序,則該方法返回定制排序所使用的Comparator;如果TreeSet采用了自然排序,則返回null

Object first():返回集合中的第一個元素

Object last():返回集合中的最后一個元素

Object lower(Object e):返回集合中位于指定元素之前的元素(即小于指定元素的最大元素,參考元素不需要是TreeSet集合里的元素)

Object higher(Object e):返回集合中位于指定元素之后的元素(即大于指定元素的最小元素,參考元素不需要是TreeSet集合里的元素)

SortedSet subSet(Object fromElement, Object toElement):返回此Set的子集,范圍從fromElement(包括)到toElement(不包括)

SortedSet headSet(Object toElement):返回此Set的子集,由小于toElement的元素組成

SortedSet tailSet(Object fromElement):返回此Set的子集,由大于或等于fromElement的元素組成

HashSet采用hash算法來決定元素的存儲位置,TreeSet采用紅黑樹的數據結構來存儲集合元素。

TreeSet支持兩種排序方法。在默認情況下,TreeSet采用自然排序

import java.util.*;

public class TreeSetTest
{
    public static void main(String[] args)
    {
        TreeSet nums = new TreeSet();
        // 向TreeSet中添加四個Integer對象
        nums.add(5);
        nums.add(2);
        nums.add(10);
        nums.add(-9);
        // 輸出集合元素,看到集合元素已經處于排序狀態
        System.out.println(nums);
        // 輸出集合里的第一個元素
        System.out.println(nums.first()); // 輸出-9
        // 輸出集合里的最后一個元素
        System.out.println(nums.last());  // 輸出10
        // 返回小于4的子集,不包含4
        System.out.println(nums.headSet(4)); // 輸出[-9, 2]
        // 返回大于5的子集,如果Set中包含5,子集中還包含5
        System.out.println(nums.tailSet(5)); // 輸出 [5, 10]
        // 返回大于等于-3,小于4的子集。
        System.out.println(nums.subSet(-3 , 4)); // 輸出[2]
    }
}
自然排序

TreeSet會調用集合元素的compareTo(Object obj)方法來比較元素之間的大小關系,然后將集合元素按升序排列,這種方式就是自然排列

compareTo(Object obj)方法返回一個整數值,實現該接口的類必須實現該方法,實現了該接口的類的對象就可以比較大小。當一個對象調用該方法與另一個對象進行比較時,例如obj1.compareTo(obj2),如果該方法返回0,則表明這兩個對象相等;如果該方法返回一個正整數,則表明obj1大于obj2;如果該方法返回一個負整數,則表明obj1小于obj2

實現了Comparable接口的常用類

BigDecimal、BigInteger以及所有的數組型對應的包裝類:按它們對應的數組大小進行比較

Character:按字符的UNICODE值進行比較

Boolean:true對應的包裝類實例大于false對應的包裝類實例

String:按字符串中字符的UNICODE值進行比較

Date、Time:后面的時間、日期比前面的時間、日期大

一個對象添加到TreeSet時,則該對象的類必須實現Comparable接口,否則程序將會拋出異常

import java.util.TreeSet;

class Error{ }
public class TreeSetErrorTest 
{
    public static void main(String[] args) 
    {
        TreeSet treeSet = new TreeSet<>();
        treeSet.add(new Error());
        treeSet.add(new Error());        //①
    }
}

添加第一個對象時,TreeSet里沒有任何元素,所以不會出現任何問題;當添加第二個Error對象時,TreeSet就會調用該對象的compareTo(Object obj)方法與集合中的其他元素進行比較——如果其對應的類沒有實現Comparable接口,則會引發ClassCastException異常

向TreeSet集合中添加元素時,只有第一個元素無須實現Comparable接口,后面添加的所有元素都必須實現Comparable接口
把一個對象添加到TreeSet集合時,TreeSet會調用該對象的compareTo(Object obj)方法與集合中的其他元素進行比較。向TreeSet中添加的應該是同一個類的對象,否則也會引發ClassCastException異常

如果希望TreeSet能正常運行,TreeSet只能添加同一種類型的對象

當把一個對象加入TreeSet集合中時,TreeSet調用該對象的compareTo(Object obj)方法與容器中的其他對象比較大小,然后根據紅黑樹結構找到它的存儲位置。如果兩個對象通過compareTo(Object obj)方法比較相等,新對象將無法添加到TreeSet集合中

定制排序

TreeSet的自然排序是根據集合元素的大小,TreeSet將它們以升序排列。如果需要實現定制排序,例如以降序排列,則可以通過Comparator接口的幫助。

class M
{
    int age;
    public M(int age)
    {
        this.age = age;
    }
    public String toString()
    {
        return "M[age:" + age + "]";
    }
}
public class TreeSetTest4
{
    public static void main(String[] args)
    {
        // 此處Lambda表達式的目標類型是Comparator
        TreeSet ts = new TreeSet((o1 , o2) ->
        {
            M m1 = (M)o1;
            M m2 = (M)o2;
            // 根據M對象的age屬性來決定大小,age越大,M對象反而越小
            return m1.age > m2.age ? -1
                : m1.age < m2.age ? 1 : 0;
        });
        ts.add(new M(5));
        ts.add(new M(-3));
        ts.add(new M(9));
        System.out.println(ts);
    }
}

EnumSet類

EnumSet是一個專為枚舉類設計的集合類,EnumSet中的所有元素都必須是指定枚舉類型的枚舉值,該枚舉類型在創建EnumSet時顯式或隱式地指定。EnumSet的集合元素也是有序的,EnumSet以枚舉值在Enum類內的定義順序來決定集合元素的順序

EnumSet在內部以位向量的形式存儲,EnumSet對象占用內存很小,運行效率很好。尤其是進行批量操作(如調用containsAll()和retainAll()方法)時,如果其參數也是EnumSet集合,則該批量操作的執行速度也非常快

EnumSet集合不允許加入null元素,否則拋出NullPointException異常

EnumSet沒有暴露任何構造器來創建該類的實例,應通過其提供的類方法來創建EnumSet對象

EnumSet allOf(Class elementType): 創建一個包含指定枚舉類里所有枚舉值的EnumSet集合

EnumSet complementOf(EnumSet e): 創建一個其元素類型與指定EnumSet里元素類型相同的EnumSet集合,新EnumSet集合包含原EnumSet集合所不包含的、此類枚舉類剩下的枚舉值(即新EnumSet集合和原EnumSet集合的集合元素加起來是該枚舉類的所有枚舉值)

EnumSet copyOf(Collection c): 使用一個普通集合來創建EnumSet集合

EnumSet copyOf(EnumSet e): 創建一個指定EnumSet具有相同元素類型、相同集合元素的EnumSet集合

EnumSet noneOf(Class elementType): 創建一個元素類型為指定枚舉類型的空EnumSet

EnumSet of(E first,E…rest): 創建一個包含一個或多個枚舉值的EnumSet集合,傳入的多個枚舉值必須屬于同一個枚舉類

EnumSet range(E from,E to): 創建一個包含從from枚舉值到to枚舉值范圍內所有枚舉值的EnumSet集合

enum Season
{
    SPRING,SUMMER,FALL,WINTER
}
public class EnumSetTest
{
    public static void main(String[] args)
    {
        // 創建一個EnumSet集合,集合元素就是Season枚舉類的全部枚舉值
        EnumSet es1 = EnumSet.allOf(Season.class);
        System.out.println(es1); // 輸出[SPRING,SUMMER,FALL,WINTER]
        // 創建一個EnumSet空集合,指定其集合元素是Season類的枚舉值。
        EnumSet es2 = EnumSet.noneOf(Season.class);
        System.out.println(es2); // 輸出[]
        // 手動添加兩個元素
        es2.add(Season.WINTER);
        es2.add(Season.SPRING);
        System.out.println(es2); // 輸出[SPRING,WINTER]
        // 以指定枚舉值創建EnumSet集合
        EnumSet es3 = EnumSet.of(Season.SUMMER , Season.WINTER);
        System.out.println(es3); // 輸出[SUMMER,WINTER]
        EnumSet es4 = EnumSet.range(Season.SUMMER , Season.WINTER);
        System.out.println(es4); // 輸出[SUMMER,FALL,WINTER]
        // 新創建的EnumSet集合的元素和es4集合的元素有相同類型,
        // es5的集合元素 + es4集合元素 = Season枚舉類的全部枚舉值
        EnumSet es5 = EnumSet.complementOf(es4);
        System.out.println(es5); // 輸出[SPRING]
    }
}

EnumSet可以復制另一個EnumSet集合中的所有元素來創建新的EnumSet集合,或者復制另一個Collection集合中的所有元素來創建新的EnumSet集合。當復制Collection集合中的所有元素來創建新的EnumSet集合時,要求Collection集合中的所有元素必須是同一個枚舉類的枚舉值

各Set實現類的性能分析

HashSet的性能總比TreeSet好,特別是最常用的添加、查詢元素等操作。因為TreeSet需要額外的紅黑樹算法來維護集合元素的次序。只有當需要保持排序的Set時,才應該使用TreeSet,否則都應該使用HashSet

LinkedHashSet是HashSet的一個子類,對于普通的插入、刪除操作,LinkedHashSet比HashSet要略微滿意的,這是由維護鏈表所帶來的額外開銷所造成的,但由于有了鏈表,遍歷LinkedHashSet會更快

EnumSet是所有Set實現類中性能最好的,但它只能保存同一個枚舉的枚舉值作為集合元素

HashSet、TreeSet、EnumSet都是線程不安全的,如果有多個線程同時訪問一個Set集合,并且有超過一個線程修改了該Set集合,則必須手動保證該Set集合的同步性。通常可以通過Collections工具類的synchronizedSortedSet方法來“包裝”該Set集合。在創建時進行,以防對Set集合的意外非同步訪問

SortedSet s = Collections.synchronizedSortedSet(new TreeSet(...));

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/66398.html

相關文章

  • java集合

    摘要:集合類簡介集合類包含在包下集合類存放的是對象的引用,而非對象本身。集合類型主要分為集,列表,映射。返回此有序集合中當前第一個最小的元素。集合中元素被訪問的順序取決于集合的類型。 Java集合類 1.簡介: java集合類包含在java.util包下集合類存放的是對象的引用,而非對象本身。集合類型主要分為Set(集),List(列表),Map(映射)。 1.1 java集合類圖 sho...

    Pluser 評論0 收藏0
  • java集合-Set

    摘要:集合判斷兩個元素的標準是兩個對象通過方法比較相等,并且兩個對象的方法返回值也相等。的集合元素也是有序的,以枚舉值在類內的定義順序來決定集合元素的順序。是所有實現類中性能最好的,但它只能保存同一個枚舉類的枚舉值作為集合元素。 Set集合通常不能記住元素的添加順序。Set不允許包含重復的元素。 Set集合不允許包含相同的元素,如果試圖把兩個相同的元素加入同一個Set集合中,則添加操作...

    xavier 評論0 收藏0
  • Java? 教程(Set接口)

    Set接口 Set是一個不能包含重復元素的Collection,它模擬了數學集抽象,Set接口僅包含從Collection繼承的方法,并添加禁止重復元素的限制,Set還為equals和hashCode操作的行為添加了一個更強的契約,允許Set實例有意義地進行比較,即使它們的實現類型不同,如果兩個Set實例包含相同的元素,則它們是相等的。 Java平臺包含三個通用的Set實現:HashSet、Tre...

    Apollo 評論0 收藏0
  • Java? 教程(集合接口)

    集合接口 核心集合接口封裝了不同類型的集合,如下圖所示,這些接口允許獨立于其表示的細節來操縱集合,核心集合接口是Java集合框架的基礎,如下圖所示,核心集合接口形成層次結構。 showImg(https://segmentfault.com/img/bVbntJW?w=402&h=146); Set是一種特殊的Collection,SortedSet是一種特殊的Set,依此類推,另請注意,層次結構...

    elisa.yang 評論0 收藏0
  • 帶你入門 JavaScript ES6 (五) 集合

    摘要:一概述集合是引入的新的內置對象類型,其特點同數學意義的集合,即集合內所有元素不重復元素唯一。數組集合對比數組和集合,數組可以加入重復數據,而集合的所有元素是唯一的不允許重復。因此,適合臨時存放一組對象,以及存放跟對象綁定的信息。 本文同步帶你入門 帶你入門 JavaScript ES6 (五) 集合,轉載請注明出處。 前面我們學習了: for of 變量和擴展語法 塊作用域變量和解構...

    BetaRabbit 評論0 收藏0
  • Java集合框架——Map接口

    摘要:第三階段常見對象的學習集合框架集合在實際需求中,我們常常會遇到這樣的問題,在諸多的數據中,通過其編號來尋找某一些信息,從而進行查看或者修改,例如通過學號查詢學生信息。面試題和的區別是單列集合的頂層接口,有子接口和。 第三階段 JAVA常見對象的學習 集合框架——Map集合 showImg(https://segmentfault.com/img/remote/1460000019683...

    princekin 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<