位置: 编程技术 - 正文

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

  • 小规模纳税人500万以内免税
  • 电子银行承兑重复背书
  • 网络团购的类型
  • 复合肥生产企业排名
  • 固定资产减值必有损益吗
  • 税务退进项税会计处理
  • 直接减免的增值税计入哪个科目
  • 前期物业管理公司
  • 存货占比小有什么影响
  • 工会经费怎么做账务处理
  • 对公账户网银证书有效期多久
  • 收到政府补贴要交增值税吗
  • 有质量问题的产品案例
  • 企业延期支付工资的法律依据
  • 运输途中发生货物丢失
  • 发行股票的承销商佣金分录
  • 计提的坏账准备可以转回吗
  • 宝塔linux面板怎么安装
  • 去年的发票今年怎么做会计分录
  • 广告费递延几年
  • 华为应用市场被锁了,怎么解除密码
  • 如何在excel中计算两列数值的差
  • 固定资产折旧计提时间
  • windows10我得电脑
  • 销售费用里面的支付的安装人工费汇算清缴时计入哪里
  • 路由器怎么设置2.4g网络
  • vue3.0 element ui
  • php多进程开发
  • php100 jquery教程
  • 自己搭建网站怎么赚钱
  • Thinkphp事务操作实例(推荐)
  • php restful接口
  • 手把手教你实现用户登录界
  • php的两种运行方式
  • 金蝶软件可以自学吗
  • vue笔记项目
  • 论文阅读网站排行榜
  • php判断文件是否存在的函数
  • useradd 删除用户
  • 深究Python中的asyncio库-线程池
  • 税收分类编码不存在什么意思
  • 自查补缴增值税附表一怎么填写
  • 个人注册投资有限公司
  • 织梦文档网站模板
  • 员工手机补助单怎么做账
  • 大华摄像头海康威视录像机
  • mysql临时表什么时候销毁
  • sql中循环语句怎么写
  • 建筑施工企业增值税税率调整时间
  • 小规模企业免税收入会计分录
  • 应收账款借方余额
  • 发货环节产生的影响
  • 实行自行申报的项目有哪些
  • 长期股权投资的账务处理
  • 水利建设基金计提会计分录
  • 无生产经营收入可以评为a吗
  • 固定资产清理明细账采用什么账簿
  • 房地产企业以土地入股如何交纳企业所得税
  • win7系统开启vt
  • 桌面上的软件是什么
  • 重装xp系统进不去
  • mac如何安装dmg软件
  • win10rs2是哪个版本
  • linux添加启动
  • linux ids
  • pavsrv51.exe - pavsrv51是什么进程 有什么用
  • win10安全问题
  • 正则表达式语法 \d
  • android模块开发
  • 易信安卓手机版
  • node.js express koa
  • android内存泄露监测
  • python按行写入txt
  • python函数判断质数
  • js验证码代码怎么写
  • 车辆购置税查询不到
  • 进出口贸易产品种类
  • 增值税税控系统专用设备及技术维护费
  • 高新企业人才落户北京
  • 境外付款需要什么手续
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设