位置: 编程技术 - 正文

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模块详解)

  • 增值税的免税项目有哪些
  • 抵消损益分录
  • 差额发票和全额发票一样吗
  • 预提的费用在做所得税的时候如何处理
  • 劳务公司开出发票3年未收到钱
  • 收到租赁费发票的账务处理
  • 固定资产计入了主营业务成本,该怎么办
  • 小规模纳税人金融服务税率
  • 向金融企业借款利息支出可以税前扣除吗
  • 对方公司倒闭应收账款发票还需要开吗
  • 货样广告品出口需要开票吗
  • 不是企业性质的民办学校要交什么税
  • 股东投入固定资产进来怎么做账
  • 投资大收益小,怎么办?
  • 建安类增值税专用发票什么时候改的
  • 子公司资不抵债
  • 研发企业退税
  • 待抵扣进项税 待认证进项税
  • 公司开年会的费用谁承担
  • Win11怎么自定义鼠标指针图案
  • 土地价款扣除会计分录
  • 扣客户的罚款会计科目
  • 在win7中如何设置屏幕保护程序
  • 政府回购企业土地
  • 设置u盘优先启动怎么设置
  • 如何使用u盘安装软件
  • 建筑业成本核算表格百度网盘
  • 企业以物易物如何确认收入
  • axios在vue中的使用慕课笔记
  • st的电机库性能怎么样呢
  • html关于边框的代码
  • 与资产相关的政府补助有哪些
  • linux suid
  • html5简单吗
  • es6对象扩展运算符
  • 帝国cms栏目可以看吗
  • javascript高阶
  • 增值税专用发票和普通发票的区别
  • 飞机票电子发票能报销吗
  • C++ 使用dll路径不在当前路径时如何调用
  • ps灰色模式怎么换回来快捷键
  • 税金及附加主要包括什么
  • 现金收入支出表怎么填
  • 现金余额不对怎么处理
  • 预缴的增值税及附加税怎么做账
  • 增值税申报表中期初未缴税额指什么
  • 资产减值损失如何计算
  • 将税后利润首先用于增加投资
  • 会议费报销时应当提供哪些材料
  • 会计建账的基本程序的六个步骤
  • Linux环境mysql5.7.12安装教程
  • mysql handshake
  • Mysql 5.7.17 winx64在win7上的安装教程
  • win帮助系统在哪里
  • mac硬盘挂载软件
  • linux diff用法
  • microsoft/微软
  • 一打字就出现windows设置
  • window10 不能上网
  • win10如何打开hlp文件
  • windows10升级后
  • jquery操作html代码
  • html初学
  • javascript数组操作方法
  • 常用的八种教学方法
  • jquery获取滚动条位置
  • Unity的WWW类的用法整理
  • JavaScript中的this
  • javascript中用于声明变量的关键字
  • document.getElementById().src
  • jquery左右滑动菜单
  • python做脚本语言怎么用
  • 湘医保缴费怎么网上缴费
  • 浙江国税qzzn
  • 如何打印纳税申报表
  • 吉林省地方税务局单位职工集资建房免征营业税
  • 企业承包经营责任制
  • 居住证在粤省事怎么查询
  • 企业间借款合同印花税怎么交
  • 作废的发票验旧之后怎么领取新发票
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设