成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

JDK源碼分析之Set類詳解

開發 后端
JDK源碼中Set類是我們開發過程中經常用到的,那么本文將會向你介紹JDK源碼中Set類的一些構造,使我們在編程中高效的應用。

JDK源碼分析Set類,因為Set類是經常要用到的,那我們知道JDK源碼中Set類在其中不可以有相同的元素,那么判斷這個元素是否相同是如何實現的呢,我們看下下面這張圖:

JDK源碼分析之Set類圖  

對JDK源碼分析之Set類在這張類圖上,首先我們看見一個經典模式的應用,那就是適配器模式,我們把map接口的對象,包裝成為了Set的接口;在代碼中,我們來分析一下;

首先,我們看一下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(); 

可見,他適配了HashMap,那么他的功能是如何委托給HashMap結構的呢?

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

在HashMap中,我們大多數時候是用value,但是在set的時候,卻很好的利用了已有類HashMap,他利用了HashMap的key的唯一性來保證存儲在Set中的元素的唯一性;

private static final Object PRESENT = new Object();

是這個HashMap所有key的value,他只是一個形式,而我們真正的數據是存在在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.    } 

調用了父類的構造函數;構造函數如下:

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

 生出了LinkedHashMap;

同理,我們一樣可見到TreeMap的實現:

  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(); 

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

對JDK源碼分析之Set類到這里,希望對你有幫助。

【編輯推薦】

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

2011-06-28 16:18:24

Qt QObject

2011-05-26 10:05:48

MongoDB

2012-09-20 10:07:29

Nginx源碼分析Web服務器

2023-02-26 08:42:10

源碼demouseEffect

2021-03-23 09:17:58

SpringMVCHttpServletJavaEE

2021-07-06 09:29:38

Cobar源碼AST

2024-06-13 07:55:19

2011-05-26 16:18:51

Mongodb

2011-06-23 13:10:39

Python 對象機制

2021-01-29 06:06:12

JDK15類加載Java

2011-08-25 15:41:42

Lua源碼

2011-08-23 13:56:12

MySQLConnection

2021-09-02 07:00:01

Glide流程Android

2009-07-09 14:57:08

JDK環境配置

2020-07-28 08:54:39

內核通信Netlink

2012-09-06 10:07:26

jQuery

2021-09-05 07:35:58

lifecycleAndroid組件原理

2022-01-06 07:06:52

KubernetesResourceAPI

2022-08-27 08:02:09

SQL函數語法

2022-05-30 07:36:54

vmstoragevmselect
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 日本成人在线观看网站 | 天天躁日日躁狠狠的躁天龙影院 | 黄色av免费网站 | 亚洲欧美激情网 | 欧美三级三级三级爽爽爽 | 一区二区三区免费 | 成人午夜免费在线视频 | 欧美一级欧美一级在线播放 | 99久久久99久久国产片鸭王 | 日韩av在线中文字幕 | 日韩成人在线电影 | 人人干人人干人人 | 午夜天堂精品久久久久 | 天天操妹子 | 国产精久久久久久 | 亚洲国产高清高潮精品美女 | 精品一区二区三区在线观看国产 | 毛片链接 | 91大神新作在线观看 | 91黄色片免费看 | 精品欧美一区二区在线观看视频 | 欧美videosex性极品hd | 99国产在线 | 国产一区二区视频免费在线观看 | 色妞av| 久久久久一区二区三区 | 亚洲国产成人精品女人久久久 | 久久精品—区二区三区 | 在线91| 日韩av电影院| 在线免费观看黄网 | 中文字幕 在线观看 | 涩爱av一区二区三区 | 亚洲国产成人精品一区二区 | 日韩一区二区三区在线视频 | 久久成人国产精品 | aaaaaaa片毛片免费观看 | 国产精品电影在线观看 | 亚洲国产黄| 日本精品一区二区三区视频 | 日韩电影一区二区三区 |