自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

JDK源碼分析之Set類(lèi)詳解

開(kāi)發(fā) 后端
JDK源碼中Set類(lèi)是我們開(kāi)發(fā)過(guò)程中經(jīng)常用到的,那么本文將會(huì)向你介紹JDK源碼中Set類(lèi)的一些構(gòu)造,使我們?cè)诰幊讨懈咝У膽?yīng)用。

JDK源碼分析Set類(lèi),因?yàn)镾et類(lèi)是經(jīng)常要用到的,那我們知道JDK源碼中Set類(lèi)在其中不可以有相同的元素,那么判斷這個(gè)元素是否相同是如何實(shí)現(xiàn)的呢,我們看下下面這張圖:

JDK源碼分析之Set類(lèi)圖  

對(duì)JDK源碼分析之Set類(lèi)在這張類(lèi)圖上,首先我們看見(jiàn)一個(gè)經(jīng)典模式的應(yīng)用,那就是適配器模式,我們把map接口的對(duì)象,包裝成為了Set的接口;在代碼中,我們來(lái)分析一下;

首先,我們看一下HashSet

  1. private transient HashMap map;  
  2.  
  3.    // Dummy value to associate with an Object in the backing Map  
  4.    private static final Object PRESENT = new Object(); 

可見(jiàn),他適配了HashMap,那么他的功能是如何委托給HashMap結(jié)構(gòu)的呢?

  1. public boolean add(E e) {  
  2.    return map.put(e, PRESENT)==null;  
  3.    } 

在HashMap中,我們大多數(shù)時(shí)候是用value,但是在set的時(shí)候,卻很好的利用了已有類(lèi)HashMap,他利用了HashMap的key的唯一性來(lái)保證存儲(chǔ)在Set中的元素的唯一性;

private static final Object PRESENT = new Object();

是這個(gè)HashMap所有key的value,他只是一個(gè)形式,而我們真正的數(shù)據(jù)是存在在key中的資源;

我們***拿到的迭代器也是:

  1. public Iterator iterator() {  
  2.   return map.keySet().iterator();  
  3.   } 

Map的keySet的迭代器;

同理,我們看看LinkedhashMap;

  1. public LinkedHashSet(int initialCapacity, float loadFactor) {  
  2.        super(initialCapacity, loadFactor, true);  
  3.    }  
  4.  
  5.    /**  
  6.     * Constructs a new, empty linked hash set with the specified initial  
  7.     * capacity and the default load factor (0.75).  
  8.     *  
  9.     * @param   initialCapacity   the initial capacity of the LinkedHashSet  
  10.     * @throws  IllegalArgumentException if the initial capacity is less  
  11.     *              than zero  
  12.     */ 
  13.    public LinkedHashSet(int initialCapacity) {  
  14.        super(initialCapacity, .75f, true);  
  15.    }  
  16.  
  17.    /**  
  18.     * Constructs a new, empty linked hash set with the default initial  
  19.     * capacity (16) and load factor (0.75).  
  20.     */ 
  21.    public LinkedHashSet() {  
  22.        super(16, .75f, true);  
  23.    } 

調(diào)用了父類(lèi)的構(gòu)造函數(shù);構(gòu)造函數(shù)如下:

  1. HashSet(int initialCapacity, float loadFactor, boolean dummy) {  
  2.  map = new LinkedHashMap(initialCapacity, loadFactor);  
  3.  } 

 生出了LinkedHashMap;

同理,我們一樣可見(jiàn)到TreeMap的實(shí)現(xiàn):

  1. private transient NavigableMap m;  
  2.  
  3. // Dummy value to associate with an Object in the backing Map  
  4. private static final Object PRESENT = new Object(); 

更多的,我們也可以理解他是一種橋接模式的一種變形,不過(guò)我想從意義上,我更愿意相信其是適配器的應(yīng)用;

對(duì)JDK源碼分析之Set類(lèi)到這里,希望對(duì)你有幫助。

【編輯推薦】

  1. JDK、SDK、JRE、JVM概念詳解
  2. JDK1.6的十大技術(shù)淺談
  3. 安裝JDK后JRE與JVM聯(lián)系淺談
  4. JDK源碼Java.lang.Boolean的淺析
  5. Linux安裝JDK與VI編輯器操作淺析
責(zé)任編輯:仲衡 來(lái)源: CSDN
相關(guān)推薦

2011-06-28 16:18:24

Qt QObject

2011-05-26 10:05:48

MongoDB

2023-02-26 08:42:10

源碼demouseEffect

2012-09-20 10:07:29

Nginx源碼分析Web服務(wù)器

2021-07-06 09:29:38

Cobar源碼AST

2021-03-23 09:17:58

SpringMVCHttpServletJavaEE

2024-06-13 07:55:19

2011-05-26 16:18:51

Mongodb

2021-01-29 06:06:12

JDK15類(lèi)加載Java

2011-06-23 13:10:39

Python 對(duì)象機(jī)制

2011-08-25 15:41:42

Lua源碼

2011-08-23 13:56:12

MySQLConnection

2021-09-02 07:00:01

Glide流程Android

2020-07-28 08:54:39

內(nèi)核通信Netlink

2009-07-09 14:57:08

JDK環(huán)境配置

2012-09-06 10:07:26

jQuery

2021-09-05 07:35:58

lifecycleAndroid組件原理

2017-01-12 14:52:03

JVMFinalRefere源碼

2022-08-27 08:02:09

SQL函數(shù)語(yǔ)法

2022-05-30 07:36:54

vmstoragevmselect
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)