simplemrucache.java

来自「一个Java持久层类库」· Java 代码 · 共 59 行

JAVA
59
字号
package org.hibernate.util;import org.apache.commons.collections.map.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 + -
显示快捷键?