欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java本地緩存的實(shí)現(xiàn)代碼

 更新時(shí)間:2017年05月06日 09:03:33   作者:Lis`s Blog  
本篇文章主要介紹了Java本地緩存的實(shí)現(xiàn)代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

使用場(chǎng)景

Java 應(yīng)用中,對(duì)于訪問(wèn)頻率高,更新少的數(shù)據(jù),通常的方案是將這類(lèi)數(shù)據(jù)加入緩存中。相對(duì)從數(shù)據(jù)庫(kù)中讀取來(lái)說(shuō),讀緩存效率會(huì)有很大提升。

在集群環(huán)境下,常用的分布式緩存有 Redis 、 Memcached 等。但在某些業(yè)務(wù)場(chǎng)景上,可能不需要去搭建一套復(fù)雜的分布式緩存系統(tǒng),在單機(jī)環(huán)境下,通常是會(huì)希望使用內(nèi)部的緩存( LocalCache )。

實(shí)現(xiàn)

這里提供了兩種 LocalCache 的實(shí)現(xiàn),一種是基于 ConcurrentHashMap 實(shí)現(xiàn)基本本地緩存,另外一種是基于 LinkedHashMap 實(shí)現(xiàn) LRU 策略的本地緩存。

基于ConcurrentHashMap的實(shí)現(xiàn)

static {
  timer = new Timer();
  map = new ConcurrentHashMap<>();
}

ConcurrentHashMap 作為緩存的存儲(chǔ)結(jié)構(gòu)。因?yàn)?ConcurrentHashMap 的線程安全的,所以基于此實(shí)現(xiàn)的 LocalCache 在多線程并發(fā)環(huán)境的操作是安全的。在 JDK1.8 中, ConcurrentHashMap 是支持完全并發(fā)讀,這對(duì)本地緩存的效率也是一種提升。通過(guò)調(diào)用 ConcurrentHashMap 對(duì) map 的操作來(lái)實(shí)現(xiàn)對(duì)緩存的操作。

私有構(gòu)造函數(shù)

privateLocalCache(){

}

LocalCache 是工具類(lèi),通過(guò)私有構(gòu)造函數(shù)強(qiáng)化不可實(shí)例化的能力。

緩存清除機(jī)制

/**
 * 清除緩存任務(wù)類(lèi)
 */
 static classCleanWorkerTaskextendsTimerTask{

   private String key;

   publicCleanWorkerTask(String key){
     this.key = key;
   }

   publicvoidrun(){
     LocalCache.remove(key);
   }
 }

清理失效緩存是由 Timer 類(lèi)實(shí)現(xiàn)的。內(nèi)部類(lèi) CleanWorkerTask 繼承于 TimerTask 用戶(hù)清除緩存。每當(dāng)新增一個(gè)元素的時(shí)候,都會(huì)調(diào)用 timer.schedule 加載清除緩存的任務(wù)。

基于LinkedHashMap的實(shí)現(xiàn)

LinkedHashMap 作為緩存的存儲(chǔ)結(jié)構(gòu)。主要是通過(guò) LinkedHashMap 的按照訪問(wèn)順序的特性來(lái)實(shí)現(xiàn) LRU 策略。

LRU

LRU Least Recently Used 的縮寫(xiě),即最近最久未使用。 LRU 緩存將會(huì)利用這個(gè)算法來(lái)淘汰緩存中老的數(shù)據(jù)元素,從而優(yōu)化內(nèi)存空間。

基于LRU策略的map

這里利用 LinkedHashMap 來(lái)實(shí)現(xiàn)基于 LRU 策略的 map 。通過(guò)調(diào)用父類(lèi) LinkedHashMap 的構(gòu)造函數(shù)來(lái)實(shí)例化 map 。參數(shù) accessOrder 設(shè)置為 true 保證其可以實(shí)現(xiàn) LRU 策略。

static classLRUMap<K,V>extendsLinkedHashMap<K,V>{

    ... // 省略部分代碼
    
    publicLRUMap(intinitialCapacity,floatloadFactor){
      super(initialCapacity, loadFactor, true);
    }

    ... // 省略部分代碼
    
    /**
     * 重寫(xiě)LinkedHashMap中removeEldestEntry方法;
     * 新增元素的時(shí)候,會(huì)判斷當(dāng)前map大小是否超過(guò)DEFAULT_MAX_CAPACITY,超過(guò)則移除map中最老的節(jié)點(diǎn);
     *
     * @param eldest
     * @return
     */
    protectedbooleanremoveEldestEntry(Map.Entry<K, V> eldest){
      return size() > DEFAULT_MAX_CAPACITY;
    }

  }

線程安全

/**
 * 讀寫(xiě)鎖
 */
private final ReadWriteLock readWriteLock = new ReentrantReadWriteLock();

private final Lock rLock = readWriteLock.readLock();

private final Lock wLock = readWriteLock.writeLock();

LinkedHashMap 并不是線程安全,如果不加控制的在多線程環(huán)境下使用的話,會(huì)有問(wèn)題。所以在 LRUMap 中引入了 ReentrantReadWriteLock 讀寫(xiě)鎖,來(lái)控制并發(fā)問(wèn)題。

緩存淘汰機(jī)制

protectedbooleanremoveEldestEntry(Map.Entry<K, V> eldest){
  return size() > DEFAULT_MAX_CAPACITY;
}

此處重寫(xiě) LinkedHashMap removeEldestEntry 方法, 當(dāng)緩存新增元素的時(shí)候,會(huì)判斷當(dāng)前 map 大小是否超過(guò) DEFAULT_MAX_CAPACITY ,超過(guò)則移除map中最老的節(jié)點(diǎn)。

緩存清除機(jī)制

緩存清除機(jī)制與 ConcurrentHashMap 的實(shí)現(xiàn)一致,均是通過(guò) timer 實(shí)現(xiàn)。

源碼地址: GitHub 

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論