位置: 编程技术 - 正文

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电子版
  • 建筑业营改增前后区别
  • 期间费用如何设置项目核算
  • 工程结算与工程施工如何结转
  • 外购一批原材料对外销售
  • 开具发票给顾客公司需要交纳什么税?
  • 职工福利费当年怎么扣
  • 延期缴纳税款的条件是什么
  • 清算汇缴报表填写模板
  • 开通分期付款
  • 自制销售清单可以公开吗
  • 期权的行权收益
  • 基金收益率
  • 个税申报的人数比工资表少了怎么办
  • 房地产企业的沙盘模型制作费会计处理
  • linux中tomcat如何启动
  • 域名停靠是病毒吗
  • 收到投资方投入原材料
  • 核定征收的企业利润怎么处理
  • PHP:pg_free_result()的用法_PostgreSQL函数
  • 采购周转材料会议记录
  • 发行股票溢价计入哪里
  • 个人投资所得税率是多少
  • php连接数据表
  • 基于php技术
  • 格里戈里耶奈尔尤伯夫
  • 资产负债表中应收账款根据什么填列
  • 前端的基本知识
  • 企业所得税营业外收入
  • init 4命令
  • php判断手机浏览记录数据
  • vue虚拟domdiff算法
  • python3.9怎么删除
  • linux服务器架设指南
  • 二手房过户需要户口本吗
  • 核定征收企业所得税的小型微利企业不得享受优惠政策
  • sql server 2016 sp2
  • mongodb operator
  • 企业收到赠送商品会计分录
  • 成本结账是什么意思
  • 行政事业单位应用方案总账,财务分析
  • 逾期的押金收入
  • 少计提的税费如何补提
  • 对外担保的效力
  • 一般纳税人的资格登记
  • 应收票据背书转让分录
  • 企业盘亏的设备会计分录
  • 企业所得税预缴2‰
  • windows2008关闭ie增强
  • win10屏幕自动变黄
  • windows隐藏
  • 方正怎么从u盘进pe
  • 安装centos6.6详细步骤
  • win7怎么随便放桌面图标
  • 如何清除Windows登录记录
  • 菜鸟教程官网app
  • ScanMailOutLook.exe - ScanMailOutLook是什么进程 有什么用
  • ubuntu怎么将文件传送到电脑
  • win10移动版能运行电脑软件吗
  • python的dict类型
  • JavaScript中数组长度的属性
  • nginx日志切割原理
  • android recyclerview 拖拽加阴影
  • unity5.x游戏开发指南
  • ubuntu20.04怎么安装
  • angularjs1.5
  • python lxml解析xml
  • [置顶]游戏名:chivalry2
  • jquery瀑布流代码
  • javascript要学到什么程度
  • jquery悬浮弹出提示框
  • js编写一个标准的单例模式类
  • boss直聘怎么注销账号
  • 北京大兴开发区房价
  • 武汉税务地区编号
  • 茶叶出口退税率为什么是9%不是13%
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设