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

Java中常用緩存Cache機(jī)制的實(shí)現(xiàn)

 更新時(shí)間:2016年10月28日 14:31:36   作者:杜瑞祺  
這篇文章主要介紹了Java中常用緩存Cache機(jī)制的實(shí)現(xiàn)代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

緩存,就是將程序或系統(tǒng)經(jīng)常要調(diào)用的對(duì)象存在內(nèi)存中,一遍其使用時(shí)可以快速調(diào)用,不必再去創(chuàng)建新的重復(fù)的實(shí)例。這樣做可以減少系統(tǒng)開銷,提高系統(tǒng)效率。

緩存主要可分為二大類:   

一、通過(guò)文件緩存,顧名思義文件緩存是指把數(shù)據(jù)存儲(chǔ)在磁盤上,不管你是以XML格式,序列化文件DAT格式還是其它文件格式; 

二、內(nèi)存緩存,也就是實(shí)現(xiàn)一個(gè)類中靜態(tài)Map,對(duì)這個(gè)Map進(jìn)行常規(guī)的增刪查.

import java.util.*; 

 //Description: 管理緩存 

 //可擴(kuò)展的功能:當(dāng)chche到內(nèi)存溢出時(shí)必須清除掉最早期的一些緩存對(duì)象,這就要求對(duì)每個(gè)緩存對(duì)象保存創(chuàng)建時(shí)間 

public class CacheManager { 
 private static HashMap cacheMap = new HashMap(); 

 //單實(shí)例構(gòu)造方法 
 private CacheManager() { 
  super(); 
 } 
 //獲取布爾值的緩存 
 public static boolean getSimpleFlag(String key){ 
  try{ 
   return (Boolean) cacheMap.get(key); 
  }catch(NullPointerException e){ 
   return false; 
  } 
 } 
 public static long getServerStartdt(String key){ 
  try { 
   return (Long)cacheMap.get(key); 
  } catch (Exception ex) { 
   return 0; 
  } 
 } 
 //設(shè)置布爾值的緩存 
 public synchronized static boolean setSimpleFlag(String key,boolean flag){ 
  if (flag && getSimpleFlag(key)) {//假如為真不允許被覆蓋 
   return false; 
  }else{ 
   cacheMap.put(key, flag); 
   return true; 
  } 
 } 
 public synchronized static boolean setSimpleFlag(String key,long serverbegrundt){ 
  if (cacheMap.get(key) == null) { 
   cacheMap.put(key,serverbegrundt); 
   return true; 
  }else{ 
   return false; 
  } 
 } 


 //得到緩存。同步靜態(tài)方法 
 private synchronized static Cache getCache(String key) { 
  return (Cache) cacheMap.get(key); 
 } 

 //判斷是否存在一個(gè)緩存 
 private synchronized static boolean hasCache(String key) { 
  return cacheMap.containsKey(key); 
 } 

 //清除所有緩存 
 public synchronized static void clearAll() { 
  cacheMap.clear(); 
 } 

 //清除某一類特定緩存,通過(guò)遍歷HASHMAP下的所有對(duì)象,來(lái)判斷它的KEY與傳入的TYPE是否匹配 
 public synchronized static void clearAll(String type) { 
  Iterator i = cacheMap.entrySet().iterator(); 
  String key; 
  ArrayList arr = new ArrayList(); 
  try { 
   while (i.hasNext()) { 
    java.util.Map.Entry entry = (java.util.Map.Entry) i.next(); 
    key = (String) entry.getKey(); 
    if (key.startsWith(type)) { //如果匹配則刪除掉 
     arr.add(key); 
    } 
   } 
   for (int k = 0; k < arr.size(); k++) { 
    clearOnly(arr.get(k)); 
   } 
  } catch (Exception ex) { 
   ex.printStackTrace(); 
  } 
 } 

 //清除指定的緩存 
 public synchronized static void clearOnly(String key) { 
  cacheMap.remove(key); 
 } 

 //載入緩存 
 public synchronized static void putCache(String key, Cache obj) { 
  cacheMap.put(key, obj); 
 } 

 //獲取緩存信息 
 public static Cache getCacheInfo(String key) { 

  if (hasCache(key)) { 
   Cache cache = getCache(key); 
   if (cacheExpired(cache)) { //調(diào)用判斷是否終止方法 
    cache.setExpired(true); 
   } 
   return cache; 
  }else 
   return null; 
 } 

 //載入緩存信息 
 public static void putCacheInfo(String key, Cache obj, long dt,boolean expired) { 
  Cache cache = new Cache(); 
  cache.setKey(key); 
  cache.setTimeOut(dt + System.currentTimeMillis()); //設(shè)置多久后更新緩存 
  cache.setValue(obj); 
  cache.setExpired(expired); //緩存默認(rèn)載入時(shí),終止?fàn)顟B(tài)為FALSE 
  cacheMap.put(key, cache); 
 } 
 //重寫載入緩存信息方法 
 public static void putCacheInfo(String key,Cache obj,long dt){ 
  Cache cache = new Cache(); 
  cache.setKey(key); 
  cache.setTimeOut(dt+System.currentTimeMillis()); 
  cache.setValue(obj); 
  cache.setExpired(false); 
  cacheMap.put(key,cache); 
 } 

 //判斷緩存是否終止 
 public static boolean cacheExpired(Cache cache) { 
  if (null == cache) { //傳入的緩存不存在 
   return false; 
  } 
  long nowDt = System.currentTimeMillis(); //系統(tǒng)當(dāng)前的毫秒數(shù) 
  long cacheDt = cache.getTimeOut(); //緩存內(nèi)的過(guò)期毫秒數(shù) 
  if (cacheDt <= 0||cacheDt>nowDt) { //過(guò)期時(shí)間小于等于零時(shí),或者過(guò)期時(shí)間大于當(dāng)前時(shí)間時(shí),則為FALSE 
   return false; 
  } else { //大于過(guò)期時(shí)間 即過(guò)期 
   return true; 
  } 
 } 

 //獲取緩存中的大小 
 public static int getCacheSize() { 
  return cacheMap.size(); 
 } 

 //獲取指定的類型的大小 
 public static int getCacheSize(String type) { 
  int k = 0; 
  Iterator i = cacheMap.entrySet().iterator(); 
  String key; 
  try { 
   while (i.hasNext()) { 
    java.util.Map.Entry entry = (java.util.Map.Entry) i.next(); 
    key = (String) entry.getKey(); 
    if (key.indexOf(type) != -1) { //如果匹配則刪除掉 
     k++; 
    } 
   } 
  } catch (Exception ex) { 
   ex.printStackTrace(); 
  } 

  return k; 
 } 

 //獲取緩存對(duì)象中的所有鍵值名稱 
 public static ArrayList getCacheAllkey() { 
  ArrayList a = new ArrayList(); 
  try { 
   Iterator i = cacheMap.entrySet().iterator(); 
   while (i.hasNext()) { 
    java.util.Map.Entry entry = (java.util.Map.Entry) i.next(); 
    a.add((String) entry.getKey()); 
   } 
  } catch (Exception ex) {} finally { 
   return a; 
  } 
 } 

 //獲取緩存對(duì)象中指定類型 的鍵值名稱 
 public static ArrayList getCacheListkey(String type) { 
  ArrayList a = new ArrayList(); 
  String key; 
  try { 
   Iterator i = cacheMap.entrySet().iterator(); 
   while (i.hasNext()) { 
    java.util.Map.Entry entry = (java.util.Map.Entry) i.next(); 
    key = (String) entry.getKey(); 
    if (key.indexOf(type) != -1) { 
     a.add(key); 
    } 
   } 
  } catch (Exception ex) {} finally { 
   return a; 
  } 
 } 

} 


package lhm.hcy.guge.frameset.cache; 

public class Cache { 
  private String key;//緩存ID 
  private Object value;//緩存數(shù)據(jù) 
  private long timeOut;//更新時(shí)間 
  private boolean expired; //是否終止 
  public Cache() { 
    super(); 
  } 

  public Cache(String key, Object value, long timeOut, boolean expired) { 
    this.key = key; 
    this.value = value; 
    this.timeOut = timeOut; 
    this.expired = expired; 
  } 

  public String getKey() { 
    return key; 
  } 

  public long getTimeOut() { 
    return timeOut; 
  } 

  public Object getValue() { 
    return value; 
  } 

  public void setKey(String string) { 
    key = string; 
  } 

  public void setTimeOut(long l) { 
    timeOut = l; 
  } 

  public void setValue(Object object) { 
    value = object; 
  } 

  public boolean isExpired() { 
    return expired; 
  } 

  public void setExpired(boolean b) { 
    expired = b; 
  } 
} 

//測(cè)試類, 
class Test { 
 public static void main(String[] args) { 
  System.out.println(CacheManager.getSimpleFlag("alksd")); 
//  CacheManager.putCache("abc", new Cache()); 
//  CacheManager.putCache("def", new Cache()); 
//  CacheManager.putCache("ccc", new Cache()); 
//  CacheManager.clearOnly(""); 
//  Cache c = new Cache(); 
//  for (int i = 0; i < 10; i++) { 
//   CacheManager.putCache("" + i, c); 
//  } 
//  CacheManager.putCache("aaaaaaaa", c); 
//  CacheManager.putCache("abchcy;alskd", c); 
//  CacheManager.putCache("cccccccc", c); 
//  CacheManager.putCache("abcoqiwhcy", c); 
//  System.out.println("刪除前的大?。?+CacheManager.getCacheSize()); 
//  CacheManager.getCacheAllkey(); 
//  CacheManager.clearAll("aaaa"); 
//  System.out.println("刪除后的大小:"+CacheManager.getCacheSize()); 
//  CacheManager.getCacheAllkey(); 


 } 
}

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

相關(guān)文章

  • spring boot使用@Async異步注解的實(shí)現(xiàn)原理+源碼

    spring boot使用@Async異步注解的實(shí)現(xiàn)原理+源碼

    通常我們都是采用多線程的方式來(lái)實(shí)現(xiàn)上述業(yè)務(wù)功能,但spring 提供更優(yōu)雅的方式來(lái)實(shí)現(xiàn)上述功能,就是@Async 異步注解,在方法上添加@Async,spring就會(huì)借助AOP,異步執(zhí)行方法,接下來(lái)通過(guò)本文給大家介紹spring boot異步注解的相關(guān)知識(shí),一起看看吧
    2021-06-06
  • java實(shí)現(xiàn)列表、集合與數(shù)組之間轉(zhuǎn)化的方法

    java實(shí)現(xiàn)列表、集合與數(shù)組之間轉(zhuǎn)化的方法

    這篇文章主要介紹了java實(shí)現(xiàn)列表、集合與數(shù)組之間轉(zhuǎn)化的方法,涉及java中列表、集合與數(shù)組相互轉(zhuǎn)換的技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2015-03-03
  • 淺談SpringBoot Bean加載優(yōu)先級(jí)的問題

    淺談SpringBoot Bean加載優(yōu)先級(jí)的問題

    這篇文章主要介紹了淺談SpringBoot Bean加載優(yōu)先級(jí)的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-11-11
  • Nebula?Graph介紹和SpringBoot環(huán)境連接和查詢操作

    Nebula?Graph介紹和SpringBoot環(huán)境連接和查詢操作

    Nebula?Graph?是一款開源的、分布式的、易擴(kuò)展的原生圖數(shù)據(jù)庫(kù),能夠承載包含數(shù)千億個(gè)點(diǎn)和數(shù)萬(wàn)億條邊的超大規(guī)模數(shù)據(jù)集,并且提供毫秒級(jí)查詢,這篇文章主要介紹了Nebula?Graph介紹和SpringBoot環(huán)境連接和查詢,需要的朋友可以參考下
    2022-10-10
  • 詳解SpringCloud的負(fù)載均衡

    詳解SpringCloud的負(fù)載均衡

    這篇文章主要介紹了SpringCloud的負(fù)載均衡的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用SpringCloud,感興趣的朋友可以了解下
    2021-03-03
  • SpringBoot HTTP 400排查方式

    SpringBoot HTTP 400排查方式

    這篇文章主要介紹了SpringBoot HTTP 400排查方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • SpringBoot中使用Flyway進(jìn)行數(shù)據(jù)庫(kù)遷移的詳細(xì)流程

    SpringBoot中使用Flyway進(jìn)行數(shù)據(jù)庫(kù)遷移的詳細(xì)流程

    本文介紹了如何在Spring Boot項(xiàng)目中使用Flyway進(jìn)行數(shù)據(jù)庫(kù)遷移,Flyway通過(guò)SQL腳本管理數(shù)據(jù)庫(kù)變更,支持自動(dòng)執(zhí)行和版本控制,避免了手動(dòng)執(zhí)行SQL腳本的錯(cuò)誤和維護(hù)困難,需要的朋友可以參考下
    2025-02-02
  • SpringBoot中靜態(tài)資源處理的7個(gè)技巧分享

    SpringBoot中靜態(tài)資源處理的7個(gè)技巧分享

    在Web應(yīng)用開發(fā)中,靜態(tài)資源(如CSS、JavaScript、圖片等)的處理是一個(gè)基礎(chǔ)但重要的環(huán)節(jié),本文將介紹SpringBoot中7種靜態(tài)資源處理技巧,希望對(duì)大家有所幫助
    2025-05-05
  • Java實(shí)現(xiàn)單鏈表SingleLinkedList增刪改查及反轉(zhuǎn) 逆序等

    Java實(shí)現(xiàn)單鏈表SingleLinkedList增刪改查及反轉(zhuǎn) 逆序等

    單鏈表是鏈表的其中一種基本結(jié)構(gòu)。一個(gè)最簡(jiǎn)單的結(jié)點(diǎn)結(jié)構(gòu)如圖所示,它是構(gòu)成單鏈表的基本結(jié)點(diǎn)結(jié)構(gòu)。在結(jié)點(diǎn)中數(shù)據(jù)域用來(lái)存儲(chǔ)數(shù)據(jù)元素,指針域用于指向下一個(gè)具有相同結(jié)構(gòu)的結(jié)點(diǎn)。 因?yàn)橹挥幸粋€(gè)指針結(jié)點(diǎn),稱為單鏈表
    2021-10-10
  • java 解析由String類型拼接的XML文件方法

    java 解析由String類型拼接的XML文件方法

    今天小編就為大家分享一篇java 解析由String類型拼接的XML文件方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-07-07

最新評(píng)論