simplemrucache.java
来自「好东西,hibernate-3.2.0,他是一开元的树杖hibernate-3.」· Java 代码 · 共 59 行
JAVA
59 行
package org.hibernate.util;
import org.apache.commons.collections.LRUMap;
import java.io.Serializable;
import java.io.IOException;
/**
* Cache following a "Most Recently Used" (MRU) algorithm for maintaining a
* bounded in-memory size; the "Least Recently Used" (LRU) entry is the first
* available for removal from the cache.
* <p/>
* This implementation uses a bounded MRU Map to limit the in-memory size of
* the cache. Thus the size of this cache never grows beyond the stated size.
*
* @author Steve Ebersole
*/
public class SimpleMRUCache implements Serializable {
public static final int DEFAULT_STRONG_REF_COUNT = 128;
private final int strongReferenceCount;
private transient LRUMap cache;
public SimpleMRUCache() {
this( DEFAULT_STRONG_REF_COUNT );
}
public SimpleMRUCache(int strongReferenceCount) {
this.strongReferenceCount = strongReferenceCount;
init();
}
public synchronized Object get(Object key) {
return cache.get( key );
}
public synchronized Object put(Object key, Object value) {
return cache.put( key, value );
}
public synchronized int size() {
return cache.size();
}
private void init() {
cache = new LRUMap( strongReferenceCount );
}
private void readObject(java.io.ObjectInputStream in) throws IOException, ClassNotFoundException {
in.defaultReadObject();
init();
}
public synchronized void clear() {
cache.clear();
}
}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?