java缓存

更新时间:2023-07-17 00:12:01 阅读: 评论:0

JAVA缓存
1 Cache类
2 CacheManager类
1 Cache类
印度王妃∙ 2 CacheManager类
JAVA缓存有两种:
一、文件缓存,是指把数据存储在磁盘上,可以XML格式,也可以序列化文件DAT格式还是其它文件格式。
二、内存缓存,也就是实现一个类中静态Map,对这个Map进行常规的增删查。
其代码如下:
JAVA缓存 - Cache类
public class Cache {
private String key;//缓存ID
private Object value;//缓存数据
private long timeOut;//更新时间
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;
pired = expired;
}
public String getKey() {
return key;
}
public long getTimeOut() {
return timeOut;
认为的英语}
public Object getValue() {
return value;
}
public void tKey(String string) {
key = string;
}
public void tTimeOut(long l) {
timeOut = l;
}
public void tValue(Object object) {
value = object;
}
public booleanisExpired() {
return expired;
}
public void tExpired(boolean b) {
expired = b;
}
}
//测试类,
class Test {
public static void main(String[] args) {
System.out.SimpleFlag("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("删除前的大小:"+CacheSize());
// CacheAllkey();
// CacheManager.clearAll("aaaa");
// System.out.println("删除后的大小:"+CacheSize());
// CacheAllkey();
} 及物和不及物动词
}
JAVA缓存 - CacheManager类
public class CacheManager {
private static HashMapcacheMap = new HashMap();
//单实例构造方法
private CacheManager() {
super();
日语 翻译}
//获取布尔值的缓存
public static booleangetSimpleFlag(String key){
try{
return (Boolean) (key);
}catch(NullPointerException e){
return fal;
}
}
public static long getServerStartdt(String key){
try {
return ((key);
} catch (Exception ex) {
return 0;
}
}
//设置布尔值的缓存
public synchronized static booleantSimpleFlag(String key,boolean flag){
if (flag &&getSimpleFlag(key)) {//假如为真不允许被覆盖
return fal;
}el{
cacheMap.put(key, flag);
return true;
}
} andromeda
public synchronized static booleantSimpleFlag(String key,longrverbegrundt){
if ((key) == null) {
cacheMap.put(key,rverbegrundt);
return true;
}el{
return fal;
}
}
//得到缓存。同步静态方法
private synchronized static Cache getCache(String key) {
return (Cache) (key);
}
//判断是否存在一个缓存
private synchronized static booleanhasCache(String key) {
ainsKey(key);
}
//清除所有缓存
public synchronized static void clearAll() {
cacheMap.clear();
}
//清除某一类特定缓存,通过遍历HASHMAP下的所有对象,来判断它的KEY与传入的TYPE是否匹配
public synchronized static void clearAll(String type) {
Iterator i = Set().iterator();
String key;
ArrayListarr = new ArrayList();
try {
while (i.hasNext()) {
java.util.Map.Entry entry = (java.util.Map.Entry) i.next();
key = (String) Key();
if (key.startsWith(type)) { //如果匹配则删除掉
arr.add(key);
}
}
for (int k = 0; k <arr.size(); k++) {
(k));
}
} catch (Exception ex) {
ex.printStackTrace();
}
}
//清除指定的缓存
public synchronized static void clearOnly(String key) {
ve(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)) { //调用判断是否终止方法
cache.tExpired(true);
}
return cache;
}el
return null;
}
//载入缓存信息
public static void putCacheInfo(String key, Cache obj, long dt,boolean expired) {
Cache cache = new Cache();
薪酬水平cache.tKey(key);
cache.tTimeOut(dt + System.currentTimeMillis()); //设置多久后更新缓存
cache.tValue(obj);
cache.tExpired(expired); //缓存默认载入时,终止状态为FALSE
cacheMap.put(key, cache);
}
//重写载入缓存信息方法
public static void putCacheInfo(String key,Cacheobj,longdt){
Cache cache = new Cache();
cache.tKey(key);
cache.tTimeOut(dt+System.currentTimeMillis());
cache.tValue(obj);
cache.tExpired(fal);
cacheMap.put(key,cache);
}
//判断缓存是否终止
public static booleancacheExpired(Cache cache) {
if (null == cache) { //传入的缓存不存在
return fal;
}
long nowDt = System.currentTimeMillis(); //系统当前的毫秒数
long cacheDt = TimeOut(); //缓存内的过期毫秒数
if (cacheDt<= 0||cacheDt>nowDt) { //过期时间小于等于零时,或者过期时间大于当前时间时,则为FALSE
return fal;
} el { //大于过期时间 即过期
return true;
}
}
//获取缓存中的大小
public static intgetCacheSize() {
return cacheMap.size();
}
//获取指定的类型的大小
public static intgetCacheSize(String type) {
int k = 0;
autumn怎么读Iterator i = Set().iterator();
String key;
try {
while (i.hasNext()) {
java.util.Map.Entry entry = (java.util.Map.Entry) i.next();
key = (String) Key();
if (key.indexOf(type) != -1) { //如果匹配则删除掉
k++;
}
}
} catch (Exception ex) {
ex.printStackTrace();
}
return k;
}
//获取缓存对象中的所有键值名称
public static ArrayListgetCacheAllkey() {
ArrayList a = new ArrayList();
try {
Iterator i = Set().iterator();
while (i.hasNext()) {
java.util.Map.Entry entry = (java.util.Map.Entry) i.next();
a.add((String) Key());
}
} catch (Exception ex) {} finally {
return a;
}
}
//获取缓存对象中指定类型 的键值名称
public static ArrayListgetCacheListkey(String type) {
ArrayList a = new ArrayList();
String key;
try {
Iterator i = Set().iterator();
while (i.hasNext()) {
java.util.Map.Entry entry = (java.util.Map.Entry) i.next();
key = (String) Key();
if (key.indexOf(type) != -1) {
a.add(key);
}
}
} catch (Exception ex) {} finally {
return a;
}
}
}

2007-09-29
简单LRU算法实现缓存
    最简单的LRU算法实现,就是利用jdk的LinkedHashMap,覆写其中的removeEldestEntry(Map.Entry)方法即可,如下所示:
java 代码
 
1. import java.util.ArrayList; 
2. import java.util.Collection; 
3. import java.util.LinkedHashMap; 
4. import urrent.locks.Lock; 
5. import urrent.locks.ReentrantLock; 
6. import java.util.Map; 
7.   
8.   
9. /** 
10.  * 类说明:利用LinkedHashMap实现简单的缓存, 必须实现removeEldestEntry方法,具体参见JDK文档 
11.  *  
12.  * @author dennis 
philadelphia
13.  *  
14.  * @param <K> 
15.  * @param <V> 
16.  */ 
17. jay anpublic class LRULinkedHashMap<K, V> extends LinkedHashMap<K, V> { 
18.     private final int maxCapacity; 
19.   
20.     private static final float DEFAULT_LOAD_FACTOR = 0.75f; 
21.   
22.     private final Lock lock = new ReentrantLock(); 
23.   
24.     public LRULinkedHashMap(intterrorblade maxCapacity) { 
25.         super(maxCapacity, DEFAULT_LOAD_FACTOR, true); 
26.         this.maxCapacity = maxCapacity; 

本文发布于:2023-07-17 00:12:01,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/fan/90/179664.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:缓存   是否   方法
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图