cn.hutool.core.map.FixedLinkedHashMap Maven / Gradle / Ivy
package cn.hutool.core.map;
import java.util.LinkedHashMap;
import java.util.Map;
import java.util.function.Consumer;
/**
* 固定大小的{@link LinkedHashMap} 实现
* 注意此类非线程安全,由于{@link #get(Object)}操作会修改链表的顺序结构,因此也不可以使用读写锁。
*
* @param 键类型
* @param 值类型
* @author looly
*/
public class FixedLinkedHashMap extends LinkedHashMap {
private static final long serialVersionUID = -629171177321416095L;
/**
* 容量,超过此容量自动删除末尾元素
*/
private int capacity;
/**
* 移除监听
*/
private Consumer> removeListener;
/**
* 构造
*
* @param capacity 容量,实际初始容量比容量大1
*/
public FixedLinkedHashMap(int capacity) {
super(capacity + 1, 1.0f, true);
this.capacity = capacity;
}
/**
* 获取容量
*
* @return 容量
*/
public int getCapacity() {
return this.capacity;
}
/**
* 设置容量
*
* @param capacity 容量
*/
public void setCapacity(int capacity) {
this.capacity = capacity;
}
/**
* 设置自定义移除监听
*
* @param removeListener 移除监听
*/
public void setRemoveListener(final Consumer> removeListener) {
this.removeListener = removeListener;
}
@Override
protected boolean removeEldestEntry(java.util.Map.Entry eldest) {
//当链表元素大于容量时,移除最老(最久未被使用)的元素
if (size() > this.capacity) {
if (null != removeListener) {
// 自定义监听
removeListener.accept(eldest);
}
return true;
}
return false;
}
}