-
Paket lhm.hcy.guge.frameset.cache;
import java.util.*;
/**
* <p>Titel: </p>
*
* <p>Beschreibung: Cache verwalten</p>
* Tiefblau 28.11.2008 denke
* Erweiterbare Funktion: Wenn Chche einen Speicherüberlauf erreicht, müssen einige der frühesten Cache-Objekte gelöscht werden, was eine Einsparung der Erstellungszeit jedes Cache-Objekts erfordert.
* <p>Copyright: Copyright (c) 2008</p>
*
* <p>Firma: </p>
*
* @author Deepblue 11.11.2008
* @Version 1.0
*/
öffentliche Klasse CacheManager {
private static HashMap cacheMap = new HashMap();
//Einzelinstanz-Konstruktionsmethode
privater CacheManager() {
super();
}
//Den Cache mit booleschen Werten abrufen
öffentlicher statischer boolescher Wert getSimpleFlag(String key){
versuchen{
return (Boolean) cacheMap.get(key);
}catch(NullPointerException e){
return false;
}
}
public static long getServerStartdt(String key){
versuchen {
return (Long)cacheMap.get(key);
} Catch (Ausnahme ex) {
0 zurückgeben;
}
}
//Legen Sie den Cache für boolesche Werte fest
öffentlicher synchronisierter statischer boolescher Wert setSimpleFlag(String key,boolean flag){
if (flag && getSimpleFlag(key)) {//Wenn true, ist das Überschreiben nicht zulässig
return false;
}anders{
cacheMap.put(key, flag);
return true;
}
}
öffentlich synchronisierter statischer boolescher Wert setSimpleFlag(String key,long serverbegrundt){
if (cacheMap.get(key) == null) {
cacheMap.put(key,serverbegrundt);
return true;
}anders{
return false;
}
}
//Hol dir den Cache. Synchronisierte statische Methoden
privater synchronisierter statischer Cache getCache(String key) {
return (Cache) cacheMap.get(key);
}
//Bestimmen Sie, ob ein Cache vorhanden ist
privater synchronisierter statischer boolescher Wert hasCache(String key) {
return cacheMap.containsKey(key);
}
//Alle Caches löschen
öffentlich synchronisiertes statisches void clearAll() {
CacheMap.clear();
}
//Löschen Sie einen bestimmten Cache-Typ und bestimmen Sie, ob sein SCHLÜSSEL mit dem eingehenden TYP übereinstimmt, indem Sie alle Objekte unter der HASHMAP durchlaufen
öffentlich synchronisiertes statisches void clearAll(String type) {
Iterator i = cacheMap.entrySet().iterator();
Zeichenfolgenschlüssel;
ArrayList<String> arr = new ArrayList<String>();
versuchen {
while (i.hasNext()) {
java.util.Map.Entry Eintrag = (java.util.Map.Entry) i.next();
key = (String) enter.getKey();
if (key.startsWith(type)) { //Bei Übereinstimmung löschen
arr.add(key);
}
}
for (int k = 0; k < arr.size(); k++) {
clearOnly(arr.get(k));
}
} Catch (Ausnahme ex) {
ex.printStackTrace();
}
}
//Löschen Sie den angegebenen Cache
öffentlich synchronisiertes statisches void clearOnly(String key) {
cacheMap.remove(key);
}
//Cache laden
öffentlich synchronisiertes statisches void putCache(String key, Cache obj) {
cacheMap.put(key, obj);
}
//Cache-Informationen abrufen
öffentlicher statischer Cache getCacheInfo(String key) {
if (hasCache(key)) {
Cache-Cache = getCache(key);
if (cacheExpired(cache)) { //Rufen Sie die Methode auf, um zu bestimmen, ob sie beendet werden soll
Cache.setExpired(true);
}
Cache zurückgeben;
}anders
null zurückgeben;
}
//Cache-Informationen laden
public static void putCacheInfo(String key, Cache obj, long dt,boolean Expired) {
Cache-Cache = neuer Cache();
Cache.setKey(key);
cache.setTimeOut(dt + System.currentTimeMillis()); //Legen Sie fest, wie lange es dauert, den Cache zu aktualisieren
Cache.setValue(obj);
Cache.setExpired(expired); //Wenn der Cache standardmäßig geladen wird, ist der Beendigungsstatus FALSE
CacheMap.put(Schlüssel, Cache);
}
//Schreiben Sie die Methode zum Laden von Cache-Informationen neu
public static void putCacheInfo(String key,Cache obj,long dt){
Cache-Cache = neuer Cache();
Cache.setKey(key);
Cache.setTimeOut(dt+System.currentTimeMillis());
Cache.setValue(obj);
Cache.setExpired(false);
cacheMap.put(key,cache);
}
//Bestimmen Sie, ob der Cache beendet ist
öffentlicher statischer boolescher CacheExpired(Cache-Cache) {
if (null == Cache) { //Der eingehende Cache existiert nicht
return false;
}
long nowDt = System.currentTimeMillis(); //Die aktuelle Anzahl der Millisekunden im System
long CacheDt = Cache.getTimeOut(); //Ablaufzeit in Millisekunden im Cache
if (cacheDt <= 0||cacheDt>nowDt) { //Wenn die Ablaufzeit kleiner oder gleich Null ist oder wenn die Ablaufzeit größer als die aktuelle Zeit ist, ist sie FALSE
return false;
} else { //Läuft ab, wenn es größer als die Ablaufzeit ist
return true;
}
}
//Größe im Cache abrufen
public static int getCacheSize() {
return cacheMap.size();
}
//Größe des angegebenen Typs abrufen
public static int getCacheSize(String type) {
int k = 0;
Iterator i = cacheMap.entrySet().iterator();
Zeichenfolgenschlüssel;
versuchen {
while (i.hasNext()) {
java.util.Map.Entry Eintrag = (java.util.Map.Entry) i.next();
key = (String) enter.getKey();
if (key.indexOf(type) != -1) { //Wenn es übereinstimmt, löschen Sie es
k++;
}
}
} Catch (Ausnahme ex) {
ex.printStackTrace();
}
Rückkehr k;
}
//Alle Schlüsselwertnamen im Cache-Objekt abrufen
öffentliche statische ArrayList<String> getCacheAllkey() {
ArrayList a = new ArrayList();
versuchen {
Iterator i = cacheMap.entrySet().iterator();
while (i.hasNext()) {
java.util.Map.Entry Eintrag = (java.util.Map.Entry) i.next();
a.add((String) enter.getKey());
}
} Catch (Ausnahme ex) {} schließlich {
gib a zurück;
}
}
//Den Schlüsselwertnamen des angegebenen Typs im Cache-Objekt abrufen
public static ArrayList<String> getCacheListkey(String type) {
ArrayList a = new ArrayList();
Zeichenfolgenschlüssel;
versuchen {
Iterator i = cacheMap.entrySet().iterator();
while (i.hasNext()) {
java.util.Map.Entry Eintrag = (java.util.Map.Entry) i.next();
key = (String) enter.getKey();
if (key.indexOf(type) != -1) {
a.add(key);
}
}
} Catch (Ausnahme ex) {} schließlich {
gib a zurück;
}
}
}
Paket lhm.hcy.guge.frameset.cache;
/**
* <p>Titel: </p>
*
* <p>Beschreibung: Cache-DTO</p>
*
* <p>Copyright: Copyright (c) 2008</p>
*
* <p>Firma: </p>
*
* @author Deepblue 11.11.2008
* @Version 1.0
*/
öffentlicher Klassen-Cache {
privater String-Schlüssel;//Cache-ID
privater Objektwert; // Cache-Daten
private long timeOut; // Aktualisierungszeit
privater boolescher Wert abgelaufen; //ob beendet werden soll
öffentlicher Cache() {
super();
}
öffentlicher Cache(String-Schlüssel, Objektwert, langes TimeOut, boolescher Wert abgelaufen) {
this.key = Schlüssel;
this.value = value;
this.timeOut = timeOut;
this.expired = abgelaufen;
}
öffentlicher String getKey() {
Eingabetaste;
}
public long getTimeOut() {
return timeOut;
}
öffentliches Objekt getValue() {
Rückgabewert;
}
public void setKey(String string) {
Schlüssel = Zeichenfolge;
}
public void setTimeOut(long l) {
timeOut = l;
}
public void setValue(Object object) {
Wert = Objekt;
}
öffentlicher boolescher Wert isExpired() {
Rückgabe abgelaufen;
}
public void setExpired(boolean b) {
abgelaufen = b;
}
}
//Testklasse,
Klassentest {
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("Größe vor dem Löschen: "+CacheManager.getCacheSize());
// CacheManager.getCacheAllkey();
// CacheManager.clearAll("aaaa");
// System.out.println("Größe nach dem Löschen: "+CacheManager.getCacheSize());
// CacheManager.getCacheAllkey();
}
}
Dieser Artikel stammt aus dem CSDN-Blog. Bitte geben Sie beim Nachdruck die Quelle an: http://blog.csdn.net/hello_zhenyu/archive/2009/12/18/5030366.aspx