溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

怎么使用Java中的EnumMap

發(fā)布時(shí)間:2021-11-04 16:09:34 來源:億速云 閱讀:246 作者:iii 欄目:web開發(fā)

這篇文章主要講解了“怎么使用Java中的EnumMap”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“怎么使用Java中的EnumMap”吧!

提到Java中集合Map,你可能常用的是HashMap/ConcurrentHashMap,但是當(dāng)Map的key是枚舉類型時(shí),是否想過使用EnumMap了?

那么當(dāng)key是枚舉類型時(shí),EnumMap和HashMap的區(qū)別是啥?

  • HashMap:使用Hash表存儲(chǔ),底層是數(shù)組,數(shù)組中存的是entry對(duì)象,默認(rèn)長(zhǎng)度是16。也就說每次向Map中加入對(duì)象,首先根據(jù)key值計(jì)算hash值,然后根據(jù)數(shù)組長(zhǎng)度放到合適的位置,當(dāng)發(fā)生沖突時(shí),使用"開鏈法",即在沖突位置加入鏈表;Java8在解決沖突時(shí),又新增了紅黑樹的解決方案??傮w來說,HashMap就是空間換時(shí)間的方式來提高訪問效率。但是假如我們已知key的所有值時(shí),是否還有必要每次都要計(jì)算hash值,然后找位置,解決沖突,甚者擴(kuò)容了...

  • EnumMap:既然已知了所有key,那么申請(qǐng)已知大小的數(shù)組,每次訪問時(shí)根據(jù)枚舉變量的ordinal值定位到數(shù)組的指定位置,存取即可,這樣是不是既高效,且不會(huì)浪費(fèi)存儲(chǔ)中間。

下面就進(jìn)入EnumMap的內(nèi)部探秘吧

在這里小編建了一個(gè)前端學(xué)習(xí)交流扣扣群:132667127,我自己整理的最新的前端資料和高級(jí)開發(fā)教程,如果有想需要的,可以加群一起學(xué)習(xí)交流

主要成員:

public class EnumMap<K extends Enum<K>, V> extends AbstractMap<K, V>
   implements java.io.Serializable, Cloneable {
// key值的枚舉類型
private final Class<K> keyType;

//根據(jù)key值的枚舉類型,會(huì)預(yù)先緩存所有的枚舉變量
private transient K[] keyUniverse;

/**
* 所有的vlaue值,數(shù)組的下標(biāo)是枚舉變量的序號(hào)(ordinal)
* 數(shù)組的內(nèi)容是map中枚舉變量對(duì)應(yīng)的vlaue
*/
private transient Object[] vals;

//當(dāng)前map的大小,
private transient int size = 0;
}

使用詳解:

假設(shè)預(yù)先定了這樣的Enum對(duì)象

public enum  WeekEnum {
   SUNDAY, MONDAY, TUESDAY, WEDNESDAY, THURSDAY, FRIDAY, SATURDAY;
}

構(gòu)造方法:

// 構(gòu)造方法使用示例
EnumMap<WeekEnum, String> weekEnumMap = new EnumMap<>(WeekEnum.class);
// 會(huì)預(yù)先獲取所有的枚舉值,然后根據(jù)枚舉值的個(gè)數(shù),創(chuàng)建相應(yīng)大小的數(shù)組用來存放value
public EnumMap(Class<K> keyType) {
this.keyType = keyType;
keyUniverse = getKeyUniverse(keyType);
vals = new Object[keyUniverse.length];
}

put方法:

// 檢查枚舉值類型,然后根據(jù)key的序號(hào),將value存入相應(yīng)下標(biāo)的數(shù)組
public V put(K key, V value) {
       typeCheck(key);

       int index = key.ordinal();
       Object oldValue = vals[index];
       vals[index] = maskNull(value);
       if (oldValue == null)
           size++;
       return unmaskNull(oldValue);
   }

get方法:

// 依然是先校驗(yàn)key值類型,然后根據(jù)key的序號(hào)去數(shù)組的位置取值
public V get(Object key) {
 return (isValidKey(key) ?
         unmaskNull(vals[((Enum<?>)key).ordinal()]) : null);
}

感謝各位的閱讀,以上就是“怎么使用Java中的EnumMap”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對(duì)怎么使用Java中的EnumMap這一問題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是億速云,小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI