java 自定义 LRU(最近最少使用)策略 实现 缓存机制
1. java提供了一个简单的方式实现LRU: LinkedHashMap
2. 自定义实现
LRU至少需要两个主要操作: 添加(add)和搜索(search)
public class LRUCache {
private Map<String, CacheEntry> map;
private CacheEntry head , tail;
private int maxSize;
public LRUCache(int maxSize){
if(maxSize < 1){
throw new IllegalArgumentException("Cache maxSize has to be at least 1");
}
this.map = new HashMap<String, CacheEntry>();
head = new CacheEntry("head","");
tail = new CacheEntry("tail", "");
head.setNext(tail);
tail.setPrev(head);
this.maxSize = maxSize;
}
public void add(String key, String value){
CacheEntry cacheEntry = map.get(key);
if(cacheEntry == null){
cacheEntry = new CacheEntry(key, value);
if(map.size() == maxSize){
//缓存达到最大数目
//删除最老的条目
CacheEntry deleteEntry = tail.getPrev();
//从map中移除
map.remove(deleteEntry.getKey());
//从队列中移除
remove(deleteEntry);
}
//添加条目到队列
addFront(cacheEntry);
//添加到map
map.put(key, cacheEntry);
}else{
//更新值
cacheEntry.setValue(value);
//访问条目
accessed(cacheEntry);
}
}
public String search(String key){
CacheEntry entry = map.get(key);
if(entry == null){
return null;
}
accessed(entry);
return entry.getValue();
}
//打印缓存内容
public void print(){
CacheEntry entry = head.getNext();
while(entry != tail){
System.out.println("{" + entry.getKey() + ":" + entry.getValue() + "}");
entry = entry.getNext();
}
System.out.println();
}
public void accessed(CacheEntry entry) {
if(entry.getPrev() != head){
remove(entry);
addFront(entry);
}
}
private void addFront(CacheEntry entry) {
//在队列的头部添加条目
CacheEntry nextEntry = head.getNext();
head.setNext(entry);
entry.setPrev(head);
entry.setNext(nextEntry);
if(nextEntry != null){
nextEntry.setPrev(entry);
}
}
private void remove(CacheEntry entry) {
if(entry == head || entry == tail){
return;//错误
}
entry.getPrev().setNext(entry.getNext());
if(entry.getNext() != null){
entry.getNext().setPrev(entry.getPrev());
}
}
}
/**
* Created by admin on 2018/3/30.
*/
public class CacheEntry {
private CacheEntry prev, next;
private String key, value;
CacheEntry(String key, String value){
this.key = key;
this.value = value;
}
public CacheEntry getPrev() {
return prev;
}
public void setPrev(CacheEntry prev) {
this.prev = prev;
}
public CacheEntry getNext() {
return next;
}
public void setNext(CacheEntry next) {
this.next = next;
}
public String getKey() {
return key;
}
public String getValue() {
return value;
}
public void setValue(String value) {
this.value = value;
}
}
java 自定义 LRU(最近最少使用)策略 实现 缓存机制的更多相关文章
- Mybatis 事务管理和缓存机制
一级缓存--SqlSession级别 数据库表tb_user User package com.example.demo.domain; public class User { private Int ...
- 146. LRU 缓存机制 + 哈希表 + 自定义双向链表
146. LRU 缓存机制 LeetCode-146 题目描述 题解分析 java代码 package com.walegarrett.interview; /** * @Author WaleGar ...
- Java实现 LeetCode 146 LRU缓存机制
146. LRU缓存机制 运用你所掌握的数据结构,设计和实现一个 LRU (最近最少使用) 缓存机制.它应该支持以下操作: 获取数据 get 和 写入数据 put . 获取数据 get(key) - ...
- 常见面试题之操作系统中的LRU缓存机制实现
LRU缓存机制,全称Least Recently Used,字面意思就是最近最少使用,是一种缓存淘汰策略.换句话说,LRU机制就是认为最近使用的数据是有用的,很久没用过的数据是无用的,当内存满了就优先 ...
- 算法之如何实现LRU缓冲淘汰策略
1)什么是缓存? 缓存是一种提高数据读取性能的技术,在硬件设计.软件开发中都有着非广泛的应用,比如常见的CPU缓存.数据库缓存.浏览器缓存等等. 2)为什么使用缓存?即缓存的特点缓存的大小是有限的,当 ...
- leetcode LRU缓存机制(list+unordered_map)详细解析
运用你所掌握的数据结构,设计和实现一个 LRU (最近最少使用) 缓存机制.它应该支持以下操作: 获取数据 get 和 写入数据 put . 获取数据 get(key) - 如果密钥 (key) 存 ...
- 每天一点点之数据结构与算法 - 应用 - 分别用链表和数组实现LRU缓冲淘汰策略
一.基本概念: 1.什么是缓存? 缓存是一种提高数据读取性能的技术,在硬件设计.软件开发中都有着非广泛的应用,比如常见的CPU缓存.数据库缓存.浏览器缓存等等. 2.为什么使用缓存?即缓存的特点缓 ...
- Q200510-03-03 :LRU缓存机制
LRU缓存机制运用你所掌握的数据结构,设计和实现一个 LRU (最近最少使用) 缓存机制.它应该支持以下操作: 获取数据 get 和 写入数据 put . 获取数据 get(key) - 如果密钥 ( ...
- Q200510-03-02: LRU缓存机制
问题: LRU缓存机制运用你所掌握的数据结构,设计和实现一个 LRU (最近最少使用) 缓存机制.它应该支持以下操作: 获取数据 get 和 写入数据 put . 获取数据 get(key) - 如果 ...
随机推荐
- axios跨域问题
最近遇到一个很奇怪的问题,在帮助测试妹子做一个小项目的时候,遇到了一个很棘手的问题,axios请求的时候报404,请求type是options,我当时的第一反应就是跨域问题,果然在console里面还 ...
- 《Implementing QuantLib》译后记
目录 <Implementing QuantLib>译后记 初心 瞎忙 收获 彩蛋 展望 就在几天之前,经历了一年时间断断续续的坚持,<Implementing QuantLib&g ...
- IntelliJ IDEA 18 周岁,吐血推进珍藏已久的必装插件
IntelliJ IDEA是目前最好最强最智能的Java IDE,前几天,他刚刚年满18岁.  本文,给大家推荐几款我私藏已久的,自己经常使用的,可以提升代码效率的插件. IDEA插件简介 常见的I ...
- js 移动端获取当前用户的经纬度
一.HTML5 geolocation的属性 if(navigator.geolocation){ navigator.geolocation.getCurrentPosition(onSuccess ...
- [转] Java中Comparator进行对象排序
[From] https://blog.51cto.com/thinklili/2063244 Java在8后引入了lambda表达式和流,使得排序方法有了变化 class User { int id ...
- Mac下Go2Shell打开配置界面
open -a Go2Shell --args config
- Mac OS 10.12后Caps lock(大写键)无法使用的解决办法
▲打开设置中的键盘选项,并切换至输入源选项标签, ▲取消勾选“使用大写锁定键来回切换“美国英文””, ▲这时再按下Caps lock即可正常使用大小写切换. ▲Update:目前macOS 10.12 ...
- express后端和fetch前端的json数据传递
在使用express做后端,前端使用fetch API来请求后端时,一般都是用 JSON 数据进行通信的. 下面是一个简单的例子: 前端: if (up) { var passwordAgain = ...
- sublime text 3 快捷键&&使用技巧
参考文章:https://github.com/jikeytang/sublime-text 这里有很多技巧http://www.jianshu.com/p/3cb5c6f2421c/ 置顶: Ctr ...
- PHP操作sqlserver乱码解决
将捕获的参数编码转换为GB2312即可 function ($string){ returen iconv("UFT-8","GB2312//IGNORE",$ ...
