Java實現本地緩存


對於緩存的作用不言而喻,可以提高查詢效率,比去DB查詢的速度要快。項目中我們經常會使用Nosql數據庫,如Redis等做緩存。但是對於數據量很小的,訪問非常頻繁的,我們也可以存在本地緩存中。我將利用concurrentHashMap等集合容器實現一個本地緩存。

1.基於concurrentHashMap的本地緩存。

      本地緩存一般使用鍵值對方式的存儲,那么在Java中肯定是選用map,由於concurrentHashMap的線程安全性,所以就選擇了這個。過期策略采用的定時清除,實現方式可以后台起一個線程去掃,也可以用定時器,本例子使用的是定時器。

 

package com.example.demoproject.demo;
 
 
import java.util.Map;
import java.util.Timer;
import java.util.TimerTask;
import java.util.concurrent.ConcurrentHashMap;
 
/**
 * <pre>
 *     基於concurrentHash的本地緩存工具類
 *     緩存刪除基於timer定時器
 * <pre>
 * @author hejianfeng
 * @date 2019/10/5
 * @param null
 * @return
 * <pre>
 * 修改記錄
 * 版本號		修訂日期		修改人		bug編號		修改內容
 * 1.0.0	  2019/10/5      hejianfeng		    		     新建
 * </pre>
 */
public class CacheUtil {
 
    //默認大小
    private static final int DEFAULT_CAPACITY = 1024;
 
    // 最大緩存大小
    private static final int MAX_CAPACITY = 10000;
 
    //默認緩存過期時間
    private static final long DEFAULT_TIMEOUT = 3600;
 
    //1000毫秒
    private static final long SECOND_TIME = 1000;
 
    //存儲緩存的Map
    private static final ConcurrentHashMap<String, Object> map;
 
    private static final Timer timer;
 
    static {
        map = new ConcurrentHashMap<>(DEFAULT_CAPACITY);
        timer = new Timer();
    }
 
    //私有化構造方法
    private CacheUtil() {
 
    }
 
    /**
     * <pre>
     *     緩存任務清除類
     * <pre>
     * @author hejianfeng
     * @date 2019/10/5
     * @param null
     * @return
     * <pre>
     * 修改記錄
     * 版本號		修訂日期		修改人		bug編號		修改內容
     * 1.0.0	  2019/10/5      hejianfeng		    		     新建
     * </pre>
     */
    static class ClearTask extends TimerTask {
        private String key;
 
        public ClearTask(String key) {
            this.key = key;
        }
 
        @Override
        public void run() {
            CacheUtil.remove(key);
        }
 
    }
 
    //==================緩存的增刪改查
 
    /**
     * <pre>
     *     添加緩存
     * <pre>
     * @author hejianfeng
     * @date 2019/10/5
     * @param key
     * @param object
     * @return void
     * <pre>
     * 修改記錄
     * 版本號		修訂日期		修改人		bug編號		修改內容
     * 1.0.0	  2019/10/5      hejianfeng		    		     新建
     * </pre>
     */
    public static boolean put(String key, Object object) {
        if (checkCapacity()) {
            map.put(key, object);
            //默認緩存時間
            timer.schedule(new ClearTask(key), DEFAULT_TIMEOUT);
            return true;
        }
        return false;
    }
 
    /**
     * <pre>
     *     添加緩存
     * <pre>
     * @author hejianfeng
     * @date 2019/10/5
     * @param key
     * @param object
     * @param time_out  :緩存過期時間:單位秒
     * @return void
     * <pre>
     * 修改記錄
     * 版本號		修訂日期		修改人		bug編號		修改內容
     * 1.0.0	  2019/10/5      hejianfeng		    		     新建
     * </pre>
     */
    public static boolean put(String key, Object object, int time_out) {
        if (checkCapacity()) {
            map.put(key, object);
            //默認緩存時間
            timer.schedule(new ClearTask(key), time_out * SECOND_TIME);
        }
        return false;
    }
 
 
    /**
     * <pre>
     *     判斷容量大小
     * <pre>
     * @author hejianfeng
     * @date 2019/10/5
     * @param
     * @return boolean
     * <pre>
     * 修改記錄
     * 版本號		修訂日期		修改人		bug編號		修改內容
     * 1.0.0	  2019/10/5      hejianfeng		    		     新建
     * </pre>
     */
    public static boolean checkCapacity() {
        return map.size() < MAX_CAPACITY;
    }
 
    /**
     * <pre>
     *     批量增加緩存
     * <pre>
     * @author hejianfeng
     * @date 2019/10/5
     * @param m
     * @param time_out
     * @return void
     * <pre>
     * 修改記錄
     * 版本號		修訂日期		修改人		bug編號		修改內容
     * 1.0.0	  2019/10/5      hejianfeng		    		     新建
     * </pre>
     */
    public static boolean put(Map<String, Object> m, int time_out) {
        if (map.size() + m.size() <= MAX_CAPACITY) {
            map.putAll(map);
            for (String key : m.keySet()) {
                timer.schedule(new ClearTask(key), time_out * SECOND_TIME);
            }
            return true;
        }
        return false;
    }
 
    /**
     * <pre>
     *     刪除緩存
     * <pre>
     * @author hejianfeng
     * @date 2019/10/5
     * @param key
     * @return void
     * <pre>
     * 修改記錄
     * 版本號		修訂日期		修改人		bug編號		修改內容
     * 1.0.0	  2019/10/5      hejianfeng		    		     新建
     * </pre>
     */
    public static void remove(String key) {
        map.remove(key);
    }
 
    /**
     * <pre>
     *     清除所有緩存
     * <pre>
     * @author hejianfeng
     * @date 2019/10/5
     * @param
     * @return void
     * <pre>
     * 修改記錄
     * 版本號		修訂日期		修改人		bug編號		修改內容
     * 1.0.0	  2019/10/5      hejianfeng		    		     新建
     * </pre>
     */
    public void clearAll() {
        if (map.size() > 0) {
            map.clear();
        }
        timer.cancel();
    }
 
    /**
     * <pre>
     *     獲取緩存
     * <pre>
     * @author hejianfeng
     * @date 2019/10/5
     * @param key
     * @return java.lang.Object
     * <pre>
     * 修改記錄
     * 版本號		修訂日期		修改人		bug編號		修改內容
     * 1.0.0	  2019/10/5      hejianfeng		    		     新建
     * </pre>
     */
    public static Object get(String key) {
        return map.get(key);
    }
 
    /**
     * <pre>
     *     是否包含某個緩存
     * <pre>
     * @author hejianfeng
     * @date 2019/10/5
     * @param key
     * @return boolean
     * <pre>
     * 修改記錄
     * 版本號		修訂日期		修改人		bug編號		修改內容
     * 1.0.0	  2019/10/5      hejianfeng		    		     新建
     * </pre>
     */
    public static boolean isContain(String key) {
        return map.contains(key);
    }
}

  

 

https://blog.csdn.net/weixin_39634532/article/details/102131226


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM