位置: 编程技术 - 正文

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

  • 白酒的品牌使用费含增值税吗
  • 增值税报表解读
  • 吴中区个体户如何办理
  • 主营业务利润和利润总额
  • 销售赠送赠品会计处理
  • 太阳能发电开票编码
  • 期间费用的界定
  • 公司的软件服务包括哪些
  • 应纳税额与应纳税额差额
  • 企业所得税季度申报填写示例
  • 开业前所有费用叫做什么
  • 结转抵扣
  • 其他应付款短期借款
  • 所得税的营业收入包括哪些
  • 进项税加计扣除什么时候开始的
  • 企业经营活动所需的资金的来源渠道有
  • 房地产企业收到预收款如何纳税
  • 电脑怎么写记事本
  • 按月计提短期借款利息12000元
  • 调增教育经费如何做账
  • 生产成本福利费用汇算清缴嘛
  • 未分配利润转增股本需要交税吗
  • 代理进出口公司结售汇
  • 广告费用的增值税税率
  • 作废的发票怎么复制开新票
  • 7月财务报表行次三大变化
  • 个体工商户是否属于法人
  • 非股东打入投资款无法返还
  • 注册资本与注册资金的区别
  • 1697510586
  • 个人所得汇算清缴是什么
  • win11打不开安全模式
  • 如何解决win10关机后usb还在供电
  • 在win7中,如何将所有窗口进行层叠排列显示
  • Win10 (21H1)Build 19043.1266更新补丁KB5005611正式版发布:附修复更新内容
  • mac系统怎么清除数据
  • 营业外收入的会计要素
  • 华沙的教堂
  • vue打包注意事项
  • yii2框架中文手册
  • 发票刮出来的奖有兑奖时间
  • PHP使用pear实现mail发送功能 windows环境下配置pear
  • 异地工程款预缴
  • 企业的职工福利费应当按照应付工资总额的14%计提
  • 帝国cms8.0
  • 预支报销单
  • 直接人工成本的计算公式
  • 税控系统如何清卡
  • 一般纳税人的账户可以随便转账到私人账户吗
  • Mysql创建通用设备管理信息系统数据库
  • 企业所得税什么时候计提
  • 银行承兑汇票包括支票吗
  • 进项税额加计10
  • 材料退库的流程
  • 应收账款和应付账款属于什么科目
  • 关于小微企业免征印花税的规定
  • 资产负债表月报的期初余额填什么
  • 息税前利润变动百分比计算公式
  • 预收账款为什么不是货币性项目
  • 建账时应考虑的问题包括下列哪三项
  • mysql存储引擎的作用
  • ubuntu for lot
  • macbook系统快捷键
  • linux top命令详解内存过高查询
  • osk.exe
  • centos nis
  • 如何进入win10安装界面
  • xp事件管理器
  • Win10最新版下载天翼云盘
  • el-select tree
  • js基础笔记
  • js设置滚动条滚到底部
  • 数据库的列名是什么
  • python xlim
  • python中zip函数的用法
  • JavaScript小技巧整理
  • 赞美税务干部对联大全集锦
  • 关于教师的采访稿问题
  • 国税开票二维码图片
  • 什么是增值税税率是多少
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设