位置: 编程技术 - 正文

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

  • 发放福利视同销售进项税要转出吗?
  • 铜川缴纳房屋契税怎么算
  • 所得税申报表的营业收入包括营业外收入吗
  • 政府工会经费收入如何做凭证
  • 各行业的利润率表
  • 政府补贴在企业怎么申请
  • 预收装修款并开发票如何转成本?
  • 固定资产完工前盘亏的工程物资净损失
  • 年终销售返利怎么算
  • 费用发票的种类
  • 公司车辆过户给公司
  • 建筑业商业保险受益人可以是公司吗
  • 职工个人负担的医疗保险可以在计算个人所得税前扣除
  • 固定资产折旧方法可以变更吗
  • 房产税先征后免会计处理
  • 承兑贴息收入账务处理怎么做?
  • 怎么知道定额发票是真是假的
  • 服务费的进项税能抵扣么
  • 预缴增值税的情况四种情形汇总表怎么填
  • 2021年windows最新版本
  • 鸿蒙系统如何删除桌面图标
  • win7为什么现在不能用了
  • 运输发票备注规定
  • WIN7系统的镜像文件在哪里
  • 股东借钱给公司怎么写借条
  • sccenter.exe - sccenter是什么进程 有什么用
  • 企业分红的会计科目
  • 公司比赛奖金计入什么科目
  • 货物退回的会计处理
  • 物业收取停车费归谁所有
  • php语言设计模式之单例模式
  • php怎么读取txt
  • 深度学习中的FPN详解
  • unity loom插件
  • cv计算机视觉定义
  • thinkphp pathinfo
  • wordpress mobile themes
  • 电子商业汇票线下清算流程
  • 增值税买一送一处理方法
  • 财政补贴收入账务处理
  • dedecms配置
  • 实施资本公积金的目的
  • 医疗机构销售药品能否加价
  • sqlserver2012安装好了桌面没有图标
  • 增值税一般纳税人是什么意思
  • 公积金贷方有余额如何做调整分录
  • 代扣代缴的社保为什么是其他应付款
  • 收据盖发票专用章会被处罚吗
  • 金税盘维护费应该计入什么科目
  • 房地产预缴增值税计算公式
  • 职工福利费的比例
  • 流动比率好说明什么
  • 公司认缴没有实缴会有什么风险
  • 向母公司贷款利率是多少
  • 现金存入银行凭证怎么写
  • 应发工资应税工资
  • 购物卡送给客户的账务处理
  • 有收入有支出怎么求和
  • 在mysql中使用什么语句来查询数据
  • 安装office提示
  • win7旗舰版激活期限已过
  • 金山卫士电脑版
  • ias.exe是什么程序
  • Windows文件夹共享权限不足
  • centos6.10安装
  • 后缀是nb是什么程序
  • unity做小地图
  • html气泡效果
  • unity3d跨平台
  • 跨浏览器跨终端的前端开发
  • unity 3d ui
  • unity3d应用
  • javascript零基础入门
  • JavaScript For...In 使用方法
  • js怎么设置图片大小
  • 外经证怎么核验
  • 税务uk数据怎么导出来
  • 个人所得税税前扣除是什么意思
  • 纳税人识别号和公司税号一样吗
  • 美国海外公司每年利润
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设