成人免费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

2021-03-23 09:17:58

SpringMVCHttpServletJavaEE

2021-07-06 09:29:38

Cobar源碼AST

2024-06-13 07:55:19

2012-09-20 10:07:29

Nginx源碼分析Web服務器

2023-02-26 08:42:10

源碼demouseEffect

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

2017-01-12 14:52:03

JVMFinalRefere源碼

2022-01-06 07:06:52

KubernetesResourceAPI

2022-05-30 07:36:54

vmstoragevmselect

2022-08-27 08:02:09

SQL函數語法

2012-09-06 10:07:26

jQuery
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久久不卡日韩美女 | 九九在线视频 | 久久精品一区二 | 精品久久国产 | 亚洲一区日韩 | 日本免费一区二区三区 | 精品电影 | 国产在线第一页 | 日韩一区二区三区精品 | 91精品国产91久久久久游泳池 | 一级黄色绿像片 | 日韩成人免费视频 | 国产午夜精品一区二区三区四区 | 五月婷婷中文 | 国产视频久 | 中文字幕亚洲视频 | 性一爱一乱一交一视频 | 亚洲成人av在线播放 | 成人在线免费 | 亚洲精品色 | 精品一区二区久久久久久久网站 | 精品久久久久久亚洲综合网 | 国产午夜久久久 | 蜜桃精品在线 | 一区二区三区免费在线观看 | 美女国产一区 | 91精品国产综合久久婷婷香蕉 | 成人性视频免费网站 | 国产视频亚洲视频 | 国产精品不卡 | 天天影视网天天综合色在线播放 | 国产精品免费一区二区三区 | 国产91观看 | 久久久一二三区 | 国产高清在线精品一区二区三区 | 欧美日韩在线免费 | 天天综合网7799精品 | 综合久久99 | 国产乱码精品一区二区三区中文 | 亚洲精品资源 | 午夜激情免费 |