中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何正確的使用WeakHashMap

發布時間:2021-03-30 16:01:43 來源:億速云 閱讀:128 作者:Leah 欄目:編程語言

這篇文章給大家介紹如何正確的使用WeakHashMap,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

?在學習WeakHashMap時了解到,如果map里面的key只有map本身引用時,就會將key對應的Entry清除掉。查看WeakHashMap的源碼發現,Entry繼承了WeakReference類,并且實例化Entry對象時,所有的key都會通過調用super(key,queue)方法保存成對實際對象的弱引用。實際上,弱引用在構造時也需要傳入一個對象的強引用作為參數。例如:

Car car = new Car(22000,"silver");
WeakReference<Car> weakCar = new WeakReference<Car>(car);

??HashMap和WeakHashMap的區別也在于此,HashMap的key是對實際對象的強引用。

??弱引用(WeakReference)的特性是:當gc線程發現某個對象只有弱引用指向它,那么就會將其銷毀并回收內存。WeakReference也會被加入到引用隊列queue中。

??理解了相關概念之后,對WeakHashMap的實際應用感到很好奇。然后發現tomcat的源碼里,實現緩存時會用到WeakHashMap。

package org.apache.tomcat.util.collections;

import java.util.Map;
import java.util.WeakHashMap;
import java.util.concurrent.ConcurrentHashMap;

public final class ConcurrentCache<K,V> {

  private final int size;

  private final Map<K,V> eden;

  private final Map<K,V> longterm;

  public ConcurrentCache(int size) {
    this.size = size;
    this.eden = new ConcurrentHashMap<>(size);
    this.longterm = new WeakHashMap<>(size);
  }

  public V get(K k) {
    V v = this.eden.get(k);
    if (v == null) {
      synchronized (longterm) {
        v = this.longterm.get(k);
      }
      if (v != null) {
        this.eden.put(k, v);
      }
    }
    return v;
  }

  public void put(K k, V v) {
    if (this.eden.size() >= size) {
      synchronized (longterm) {
        this.longterm.putAll(this.eden);
      }
      this.eden.clear();
    }
    this.eden.put(k, v);
  }
}

??源碼中有eden和longterm的兩個map,對jvm堆區有所了解的話,可以猜測出tomcat在這里是使用ConcurrentHashMap和WeakHashMap做了分代的緩存。在put方法里,在插入一個k-v時,先檢查eden緩存的容量是不是超了。沒有超就直接放入eden緩存,如果超了則鎖定longterm將eden中所有的k-v都放入longterm。再將eden清空并插入k-v。在get方法中,也是優先從eden中找對應的v,如果沒有則進入longterm緩存中查找,找到后就加入eden緩存并返回。

??經過這樣的設計,相對常用的對象都能在eden緩存中找到,不常用(有可能被銷毀的對象)的則進入longterm緩存。而longterm的key的實際對象沒有其他引用指向它時,gc就會自動回收heap中該弱引用指向的實際對象,弱引用進入引用隊列。longterm調用expungeStaleEntries()方法,遍歷引用隊列中的弱引用,并清除對應的Entry,不會造成內存空間的浪費。

關于如何正確的使用WeakHashMap就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

黄大仙区| 响水县| 宜兰市| 闵行区| 壶关县| 桐庐县| 水富县| 灵宝市| 大埔区| 正定县| 炎陵县| 长丰县| 威远县| 达孜县| 涿州市| 修水县| 望谟县| 策勒县| 孟村| 城步| 天峻县| 正蓝旗| 常熟市| 丰城市| 项城市| 莱阳市| 黄浦区| 页游| 化德县| 中方县| 凤庆县| 安远县| 静安区| 怀安县| 甘谷县| 常宁市| 宁海县| 石林| 军事| 临沂市| 桃源县|