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(最近最少使用)策略 实现 缓存机制的更多相关文章

  1. Mybatis 事务管理和缓存机制

    一级缓存--SqlSession级别 数据库表tb_user User package com.example.demo.domain; public class User { private Int ...

  2. 146. LRU 缓存机制 + 哈希表 + 自定义双向链表

    146. LRU 缓存机制 LeetCode-146 题目描述 题解分析 java代码 package com.walegarrett.interview; /** * @Author WaleGar ...

  3. Java实现 LeetCode 146 LRU缓存机制

    146. LRU缓存机制 运用你所掌握的数据结构,设计和实现一个 LRU (最近最少使用) 缓存机制.它应该支持以下操作: 获取数据 get 和 写入数据 put . 获取数据 get(key) - ...

  4. 常见面试题之操作系统中的LRU缓存机制实现

    LRU缓存机制,全称Least Recently Used,字面意思就是最近最少使用,是一种缓存淘汰策略.换句话说,LRU机制就是认为最近使用的数据是有用的,很久没用过的数据是无用的,当内存满了就优先 ...

  5. 算法之如何实现LRU缓冲淘汰策略

    1)什么是缓存? 缓存是一种提高数据读取性能的技术,在硬件设计.软件开发中都有着非广泛的应用,比如常见的CPU缓存.数据库缓存.浏览器缓存等等. 2)为什么使用缓存?即缓存的特点缓存的大小是有限的,当 ...

  6. leetcode LRU缓存机制(list+unordered_map)详细解析

    运用你所掌握的数据结构,设计和实现一个  LRU (最近最少使用) 缓存机制.它应该支持以下操作: 获取数据 get 和 写入数据 put . 获取数据 get(key) - 如果密钥 (key) 存 ...

  7. 每天一点点之数据结构与算法 - 应用 - 分别用链表和数组实现LRU缓冲淘汰策略

    一.基本概念: 1.什么是缓存? 缓存是一种提高数据读取性能的技术,在硬件设计.软件开发中都有着非广泛的应用,比如常见的CPU缓存.数据库缓存.浏览器缓存等等.   2.为什么使用缓存?即缓存的特点缓 ...

  8. Q200510-03-03 :LRU缓存机制

    LRU缓存机制运用你所掌握的数据结构,设计和实现一个 LRU (最近最少使用) 缓存机制.它应该支持以下操作: 获取数据 get 和 写入数据 put . 获取数据 get(key) - 如果密钥 ( ...

  9. Q200510-03-02: LRU缓存机制

    问题: LRU缓存机制运用你所掌握的数据结构,设计和实现一个 LRU (最近最少使用) 缓存机制.它应该支持以下操作: 获取数据 get 和 写入数据 put . 获取数据 get(key) - 如果 ...

随机推荐

  1. GraphQL 如何取代 Redux

    简评:使用 GraphQL 可以大大简化客户端状态管理部分的代码. ⚛️切换到React 故事背景:在 2016 年,Pathwright 的前端团队就开始将客户端的代码从 Backbone & ...

  2. jpetStore 学习总结(2)

    在写jpetstore时,最难理解的应该是数据库还有每个表之间的关系了,我在这里对数据库简单的介绍. 以下是数据库的所有表:    account表是个人信息表,里面包括用户的名字,邮箱,地址,哪个城 ...

  3. C#-WebForm 如何获取下拉列表选中的值 jquery

    分别使用javascript原生的方法和jquery方法<select id="test" name=""> <option value=&q ...

  4. 【JS新手教程】浏览器弹出div层1

    JS中,可以弹出一个层来进行提示等作用,方法是利用css样式display样式,当display等于none时,该元素就不会在页面显示出来,而且元素也不会占空间.就是用户触发某些事件时,动态修改该样式 ...

  5. npm install 报错:ERR! code EINTEGRITY 解决方案

    npm升级后,npm install 报错了,报错信息:ERR! code EINTEGRITY到处百度搜索解决方案,终于找到了!“npm cache verify”这条命令帮助了不少人 npm ca ...

  6. Mac 10.12安装流量监控软件Magican

    说明:Magican这家公司已经不维护了,但是软件是单机版的,可以正常使用,但是有些10.12的机器应该是无法看到每个进程的明细,总速度可以正常显示. 下载: (链接: https://pan.bai ...

  7. Capture Conversion解读

    Let G name a generic type declaration with n type parameters A1,...,An with corresponding bounds U1, ...

  8. Spring AMQP

    Spring AMQP 是基于 Spring 框架的AMQP消息解决方案,提供模板化的发送和接收消息的抽象层,提供基于消息驱动的 POJO的消息监听等,很大方便我们使用RabbitMQ程序的相关开发. ...

  9. C#控制台程序,运行完窗口不退出的方法

    .... static void Main(string[] args){ Console.WriteLine("运行完后不退出窗口"); Console.ReadKey();// ...

  10. Java的枚举类型

    引用并转载于:http://blog.csdn.net/ishallwin/article/details/9440251 1.什么是枚举: 在实际编程中,往往存在着这样的“数据集”,它们的数值在程序 ...