位置: 编程技术 - 正文

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

  • 2023小规模免税收入会计分录怎么写啊
  • 已抵扣的进项税额怎么转出
  • 土地增值税常见问题及解答
  • 消防工程改造怎么做账务处理
  • 单位为个人负担工资、薪金所得的个税,怎么征收个税
  • 企业所得税工资薪金支出怎么填
  • 应付账款不用付怎么处理
  • 少提的税金如何做账
  • 工会活动购买物品会计分录
  • 土地无形资产摊销的会计处理
  • 购进原材料验收入库,贷款商业汇票结算
  • 融资租赁中承租人的权利
  • 百望税控盘电子发票
  • 计提的管理费用要结转吗
  • 未达到起征点销售额会计分录
  • 包装物报废收回残料
  • 应交税费的余额怎么计算
  • 一次性收取一年服务费怎么确定收入
  • 2019一般纳税人和小规模纳税人的区别
  • 测量仪器进工程成本的什么科目?
  • 如果网页上有错字怎么办
  • 金税三期怎么更正申报
  • PHP:spl_object_hash()的用法_spl函数
  • 房产契税如何计算2021年
  • 税务发票上的账户是对公账户吗
  • 一般纳税人差额征税申报表怎么填
  • 离职后原单位不给开离职证明
  • 股权激励的账务如何处理
  • vue set-cookie
  • php是面向对象编程吗
  • 油卡预付卡发票能入费用吗怎么入账
  • nfs4挂载
  • 房租费可以一次性摊销吗
  • 金税第一次使用怎么用
  • 哪些税金不需要通过应交税费科目核算
  • 开票一定要确认发票吗
  • 前端日报
  • 汇款和转账有什么区别吗
  • 设备安装收入税率
  • 资产负债表固定资产清理
  • 税控系统维护费抵扣申报表怎么填
  • 工会筹备金和工会经费滞纳金计算一样吗
  • 股票的价格是由什么决定
  • 企业的股息红利所得要交税吗
  • 现金净流量的计算公式正确的有
  • 营改增和个税改革的意义
  • 折扣折让红字发票
  • 生产过程中产品质量问题
  • 公户网银转账操作流程
  • 分期付款购买商品如何定价
  • 小规模纳税人计算公式
  • 月底现金余额
  • 跨年度固定资产转为在建工程怎么计算
  • 财务人员的职工福利费应计入?
  • 删除一组数据中的指定数据
  • mysql密码忘记了怎么找回
  • cf游戏初始化失败是因为什么
  • windows vista(service pack1)
  • win7桌面库图标怎么删除
  • CentOS系统中与时间的相关命令详解
  • 恢复window
  • win7系统安装谷歌浏览器
  • sentstrt.exe - sentstrt进程是什么文件 有什么用
  • 关机你的电脑遇到问题,需要重新启动,我们只收集
  • sendmail邮件服务器
  • win10系统经典桌面
  • virtualbox怎么打开虚拟机
  • win7系统打不开设备与打印机
  • python挑战
  • jquery教程
  • Formatting Long Lines 格式化多行字符的shell脚本
  • linux jdk
  • dos基本命令大全关机
  • JavaScript中String.match()方法的使用详解
  • java script和java区别
  • 用jquery写注册界面
  • javascript面向对象编程
  • jquery 导航
  • 浙江发票查验不了什么原因
  • 深圳海关属于省级吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设