亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

Java WeakHashMap案例詳解

瀏覽:3日期:2023-12-09 15:12:17

WeakHashMap 繼承于AbstractMap,實現了Map接口。和HashMap一樣,WeakHashMap 也是一個散列表,它存儲的內容也是鍵值對(key-value)映射,而且鍵和值都可以是null。不過WeakHashMap的鍵是“弱鍵”。在 WeakHashMap 中,當某個鍵不再正常使用時,會被從WeakHashMap中被自動移除。更精確地說,對于一個給定的鍵,其映射的存在并不阻止垃圾回收器對該鍵的丟棄,這就使該鍵成為可終止的,被終止,然后被回收。某個鍵被終止時,它對應的鍵值對也就從映射中有效地移除了。這個“弱鍵”的原理呢?大致上就是,通過WeakReference和ReferenceQueue實現的。 WeakHashMap的key是“弱鍵”,即是WeakReference類型的;ReferenceQueue是一個隊列,它會保存被GC回收的“弱鍵”。實現步驟是:(01) 新建WeakHashMap,將“鍵值對”添加到WeakHashMap中。實際上,WeakHashMap是通過數組table保存Entry(鍵值對);每一個Entry實際上是一個單向鏈表,即Entry是鍵值對鏈表。(02) 當某“弱鍵”不再被其它對象引用,并被GC回收時。在GC回收該“弱鍵”時,這個“弱鍵”也同時會被添加到ReferenceQueue(queue)隊列中。(03) 當下一次我們需要操作WeakHashMap時,會先同步table和queue。table中保存了全部的鍵值對,而queue中保存被GC回收的鍵值對;同步它們,就是刪除table中被GC回收的鍵值對。這就是“弱鍵”如何被自動從WeakHashMap中刪除的步驟了。

和HashMap一樣,WeakHashMap是不同步的。可以使用 Collections.synchronizedMap 方法來構造同步的 WeakHashMap

既然有WeakHashMap,那么有WeakHashSet嗎?  java collections包是沒有直接提供WeakHashSet的。

我們可以通過Collections.newSetFromMap(Map<E,Boolean> map)方法可以將任何 Map包裝成一個Set。源碼如下:

public static <E> Set<E> newSetFromMap(Map<E, Boolean> map) {return new SetFromMap<>(map); } /** * @serial include */ private static class SetFromMap<E> extends AbstractSet<E>implements Set<E>, Serializable {private final Map<E, Boolean> m; // The backing mapprivate transient Set<E> s; // Its keySet SetFromMap(Map<E, Boolean> map) { if (!map.isEmpty())throw new IllegalArgumentException('Map is non-empty'); m = map; s = map.keySet();} public void clear() {m.clear(); }public int size() { return m.size(); }public boolean isEmpty() { return m.isEmpty(); }public boolean contains(Object o) { return m.containsKey(o); }public boolean remove(Object o) { return m.remove(o) != null; }public boolean add(E e) { return m.put(e, Boolean.TRUE) == null; }public Iterator<E> iterator() { return s.iterator(); }public Object[] toArray() { return s.toArray(); }public <T> T[] toArray(T[] a) { return s.toArray(a); }public String toString() { return s.toString(); }public int hashCode() { return s.hashCode(); }public boolean equals(Object o) { return o == this || s.equals(o); }public boolean containsAll(Collection<?> c) {return s.containsAll(c);}public boolean removeAll(Collection<?> c) {return s.removeAll(c);}public boolean retainAll(Collection<?> c) {return s.retainAll(c);}

就是對傳入的map進行了簡單的包裝

到此這篇關于Java WeakHashMap案例詳解的文章就介紹到這了,更多相關Java WeakHashMap內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Java
相關文章:
主站蜘蛛池模板: www日本黄色 | 福利视频在线观看视频 | 免费成人福利视频 | 久久99国产精一区二区三区 | 视频在线观看国产 | 在线视频 一区二区 | 亚洲国产精品不卡毛片a在线 | 久久久久免费精品视频 | 国产一级爱片在线播放 | 成人福利免费视频 | 视频一区二区三区蜜桃麻豆 | 日韩 欧美 国产 亚洲 中文 | 精品一区二区三区免费毛片爱 | 欧美日韩在线视频不卡一区二区三区 | 露脸真实国产精品自在| 国产免费高清mv视频在线观看 | 999精品在线视频 | 国产精彩 | 特级黄色一级片 | 色成人在线 | 美女一级牲交毛片视频 | 国产欧美日韩在线一区二区不卡 | 在线一区视频 | 香蕉视频在线看 | 国产自在自线2021 | bt 自拍 另类 综合 欧美 | 精品成人免费一区二区在线播放 | 1级a的观看视频 | 国产只有精品 | 黄片毛片在线看 | 天天影视欧美综合在线观看 | 亚洲一区二区约美女探花 | 国产成人精品日本亚洲语音1 | 99久热只有精品视频免费观看17 | 黄免费视频| 九九99精品| 国产精彩| 在线国产欧美 | 一级全黄男女免费大片 | 国产欧美性综合视频性刺激 | 伊人久久久 |