新聞中心
Java中WeakHashMap如何使用,針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
創(chuàng)新互聯(lián)主要業(yè)務有網(wǎng)站營銷策劃、成都網(wǎng)站設計、成都網(wǎng)站建設、微信公眾號開發(fā)、重慶小程序開發(fā)公司、H5建站、程序開發(fā)等業(yè)務。一次合作終身朋友,是我們奉行的宗旨;我們不僅僅把客戶當客戶,還把客戶視為我們的合作伙伴,在開展業(yè)務的過程中,公司還積累了豐富的行業(yè)經(jīng)驗、成都全網(wǎng)營銷資源和合作伙伴關系資源,并逐漸建立起規(guī)范的客戶服務和保障體系。
1. WeakHashMap類概述
WeakHashMap
是一個基于Hash表的Map接口實現(xiàn)的弱鍵。當其密鑰不再正常使用時,將自動刪除該條目中的條目。支持空值和空值。該類具有與HashMap類相似的性能特征,并具有與初始容量和負載因子相同的效率參數(shù)。與大多數(shù)集合類一樣,此類不同步??梢允褂靡韵聛順嬙? 同步 WeakHashMap
WeakHashMap
Collections.synchronizedMap
方法。弱引用 - 如果對象的唯一引用是弱引用,則垃圾收集器可以隨時回收對象的內(nèi)存。它不必等到系統(tǒng)內(nèi)存不足。通常,它將在下次垃圾收集器運行時釋放。此類是Java Collections Framework的成員。
2. WeakHashMap類構造函數(shù)
WeakHashMap()
-WeakHashMap
使用默認初始容量(16)和加載因子(0.75)構造一個新的空 。WeakHashMap(int initialCapacity)
-WeakHashMap
使用給定的初始容量和默認加載因子(0.75)構造一個新的空。WeakHashMap(int initialCapacity, float loadFactor)
-WeakHashMap
使用給定的初始容量和給定的加載因子構造一個新的空 。WeakHashMap(Map< ?extends K,? extends V> m)
- 構造一個WeakHashMap
與指定映射具有相同映射的new 。
3. WeakHashMap類方法
void clear()
- 從此映射中刪除所有映射。boolean containsKey(Object key)
- 如果此映射包含指定鍵的映射,則返回true。boolean containsValue(Object value)
- 如果此映射將一個或多個鍵映射到指定值,則返回true。Set<
Map.Entry
-返回此映射中包含的映射的Set視圖。>entrySet() void forEach(BiConsumer action)
- 對此映射中的每個條目執(zhí)行給定操作,直到處理完所有條目或操作引發(fā)異常。V get(Object key)
- 返回指定鍵映射到的值,如果此映射不包含鍵的映射,則返回null。boolean isEmpty()
- 如果此映射不包含鍵 - 值映射,則返回true。Set keySet()
- 返回此映射中包含的鍵的Set視圖。V put(K key, V value)
- 將指定值與此映射中的指定鍵相關聯(lián)。void putAll(Map m)
-將指定映射中的所有映射復制到此映射。V remove(Object key)
- 如果存在,則從此弱哈希映射中刪除鍵的映射。void replaceAll(BiFunctionfunction)
- 將每個條目的值替換為在該條目上調(diào)用給定函數(shù)的結(jié)果,直到所有條目都已處理或函數(shù)拋出異常。int size()
- 返回此映射中鍵 - 值映射的數(shù)量。Collection values()
- 返回此映射中包含的值的Collection視圖。
4. WeakHashMap類示例
如我們所知,當一個條目中的條目不再被外部引用并且密鑰到期時,它將被自動刪除。在這個例子中,我們創(chuàng)建了兩個鍵 - key1和key2 - 值為“ACTIVE”和“INACTIVE”?,F(xiàn)在,使key1為null并運行該程序。輸出應該是單個條目: WeakHashMap
導入 java。util。地圖 ;
導入 java。util。地圖。進入 ;
導入 java。util。WeakHashMap ;
公共 類 WeakHashMapExample {
public static void main(final String [] args){
final Map < Key,Project > map = new WeakHashMap <>();
Key key1 = new Key(“ACTIVE”);
final key key2 = new Key(“INACTIVE”);
地圖。put(key1,new Project(100,“Customer Management System”,“Customer Management System”));
地圖。put(key2,new Project(200,“Employee Management System”,“Employee Management System”));
key1 = null ;
系統(tǒng)。gc();
為(最終 條目< 鍵,項目> 條目:地圖。的entrySet()){
系統(tǒng)。出。的println(條目。信息getKey()。信息getKey()+ “” + 條目。的getValue());
}
}
}
class Key {
私有 String 鍵 ;
public Key(final String key){
super();
這個。key = key ;
}
public String getKey(){
返回 鍵 ;
}
public void setKey(final String key){
這個。key = key ;
}
}
輸出:
INACTIVE [ 項目 編號:200,項目 名稱:員工 管理 系統(tǒng),
項目 說明:員工 管理 系統(tǒng) ]
關于Java中WeakHashMap如何使用問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關知識。
網(wǎng)頁標題:Java中WeakHashMap如何使用
網(wǎng)頁網(wǎng)址:http://fisionsoft.com.cn/article/ghpgig.html