位置: 编程技术 - 正文

LRUCache的实现原理及利用python实现的方法(lrucache算法)

编辑:rootadmin

推荐整理分享LRUCache的实现原理及利用python实现的方法(lrucache算法),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:实现lru算法所需的硬件支持是什么?,lrucache算法,实现lru算法常用方法有几种,lru实现原理,lru实现原理,lrucache算法,实现lru算法常用方法有几种,lrucache原理,内容如对您有帮助,希望把文章链接给更多的朋友!

简介

LRU(Least Recently Used)最近最少使用,最近有时间和空间最近的歧义,所以我更喜欢叫它近期最少使用算法。它的核心思想是,如果一个数据被访问过,我们有理由相信它在将来被访问的概率就越高。于是当LRU缓存达到设定的最大值时将缓存中近期最少使用的对象移除。LRUCache内部使用LinkedHashMap来存储key-value键值对,并将LinkedHashMap设置为访问顺序来体现LRU算法。

无论是对某个key的get,还是set都算做是对该key的一次使用。当set一个不存在的key,并且LRU Cache中key的数量超过cache size的时候,需要将使用时间距离现在最长的那个key从LRU Cache中清除。

LRU Cache实现

在Java中,LRUCache是通过LinkedHashMap实现的。鄙人照猫画虎,实现一个Python版的LRU Cache(可能和其他大神的实现有所区别)。

首先,需要说明的是:

LRU Cache对象内部会维护一个 双端循环链表 的 头节点

LRU Cache对象内部会维护一个dict

LRUCache的实现原理及利用python实现的方法(lrucache算法)

内部dict的value都是Entry对象,每个Entry对象包含:

key的hash_code(hash_code = hash(key),在本实现中,hash_code相同的不同key,会被当作一个key来处理。因此,对于自定义类,应该实现魔术方法:__hash__) v - (key, value)对中的value prev - 前一个对象 next - 后一个对象

具体实现是:

当从LRU Cache中get一个key的时候:

计算该key的hash_code 从内部dict中获取到entry 将该entry移动到 双端循环链表 的 第一个位置 返回entry.value

当向LRU Cache中set一个(key, value)对的时候:

计算该key的hash_code,

从LRU Cache的内部dict中,取出该hash_code对应的old_entry(可能不存在),然后根据(key, value)对生成一个new_entry,之后执行:

dict[hash_code] = new_entry 将new_entry提到 双端循环链表 的第一个位置 如果old_entry存在,则从链表中删除old_entry 如果是新增了一个(key, value)对,并且cache中key的数量超过了cache size,那么将双端链表的最后一个元素删除(该元素就是那个最近最少被使用的元素),并且从内部dict中删除该元素

HashMap的实现原理

(面试过程中也经常会被问到):数组和链表组合成的链表散列结构,通过hash算法,尽量将数组中的数据分布均匀,如果hashcode相同再比较equals方法,如果equals方法返回false,那么就将数据以链表的形式存储在数组的对应位置,并将之前在该位置的数据往链表的后面移动,并记录一个next属性,来指示后移的那个数据。

注意:数组中保存的是entry(其中保存的是键值)

Python实现

总结

标签: lrucache算法

本文链接地址:https://www.jiuchutong.com/biancheng/372311.html 转载请保留说明!

上一篇:Python利用itchat对微信中好友数据实现简单分析的方法(利用python进行)

下一篇:django模型层(model)进行建表、查询与删除的基础教程(django模块详解)

  • 一般纳税人转为小规模纳税人
  • 合伙企业主要缴纳的税种?
  • 税务局代个人开发票
  • 哪些福利费可以进在建工程
  • 免交的附加税需要计提吗
  • 计提 增值税
  • 进项税转出主要内容包括
  • 小规模纳税人第一次网上报税
  • 资金账簿印花税减半征收是从什么时候开始的
  • 怎么调整应收账款账龄
  • 债券利息收入的增值税
  • 需要月报的税收项目
  • 一般纳税人可以开普票吗
  • 加油票不打公司会怎么样
  • 天猫运费险是按照每一单结算的吗
  • 公司账上的存货是怎么来的
  • 企业核销应收账款需要什么资料
  • 非正常损失和非正常损耗的区别
  • 如何进行网络测试网速测试
  • 一般纳税人增值税申报表怎么填写
  • windows11正式版好用吗
  • win7为什么那么好用
  • 差额发票可以开1个点吗?
  • 关闭固定在任务栏的功能
  • 笔记本thinkbook14
  • 内置管理员无法打开此应用
  • wordpress的文章在数据库里吗?
  • 政府奖励怎么做账
  • 应收账款保理的主要意图在于
  • 年金单位缴费计入个人账户(税前)
  • php对二维数组进行排序
  • 罗马湖在哪
  • 陶尔米纳电影节
  • 销售商品的结转
  • Joomla简单判断用户是否登录的方法
  • php快速推送微信内容
  • 电子发票有哪些种类
  • php底层原理
  • c#开发入门及项目实战
  • html5简单吗
  • 实现扩展功能的快捷键
  • php fopen函数的用法
  • java聚合工程
  • 未开票收入如何做会计分录
  • 商品发生销售退回
  • 外贸出口退税进项发票有多家供应商怎么匹配
  • 运费和什么有关
  • 充电口有烧焦味怎么简单解决
  • mysql几千万条数据
  • sqlserver2012无法新建表
  • 公司收取保证金合法吗
  • 物流企业货损赔付标准
  • 红冲暂估原材料如何做会计分录
  • 单位买的职工社保自己可以去社保局领卡吗
  • 新建厂房房产证办理流程
  • 五险一金会计科目分录
  • 行政单位年终奖的相关发放规定
  • 工业企业外购材料采购成本包括
  • window磁铁
  • linux file-nr
  • 苹果系统装win8
  • windows ftp软件
  • mac无法开机怎么办
  • win7系统禁用网络后如何开启
  • win8自带软件哪些可以卸载
  • unity3d读取gis数据
  • 绘制多边形工具使用方法
  • javascript对象的种类
  • windows批处理官方教程
  • 什么是碰撞检测
  • javascript声明变量的语句
  • 谈谈我对美国的印象
  • Android GridView属性集合
  • JavaScript ParseFloat()方法
  • Android之Broadcast与BroadcastReceiver
  • 新疆国税网上营业厅
  • 应税和非应税是什么意思
  • 葫芦岛市税务局电话
  • 3%增值税专用发票成本多少钱
  • 幼儿掌握概念的名称容易真正掌握概念的内涵也很容易
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设