位置: 编程技术 - 正文

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

  • 公转私做账麻烦吗
  • 税金返还需要交税吗
  • 营业成本包括哪些费用
  • 应交税费科目的借贷方向
  • 合同取得成本如何结转
  • 增值税申报表中应税货物销售额
  • 外债利息支付需要按照天计算吗?
  • 研发支出期末余额列报
  • 技术服务出口免关税政策
  • 事业单位人员租房有补助吗
  • 纳税人如何申请享受税收减免优惠
  • 非货币性资产交换的记忆口诀
  • 出口抵内销产品应纳税额分录
  • 物料损耗会计分录
  • 合并重组案例
  • 交房租对方开发票怎么开
  • 一般纳税人购入货物相关的增值税可以抵扣
  • 应征消费税的汽车为啥不能抵扣
  • 为什么有的公司没有一金
  • 银行承兑汇票盖已承兑登记
  • 企业税前扣除凭证包括以下哪些方面
  • 非银行支付机构条例(征求意见稿)
  • 工厂生产的配件怎么入账
  • 认证过的发票
  • 回盘的模板
  • 研发支出采用什么明细账
  • 企业高管需要什么证书
  • 工会残保金必须缴纳吗
  • 固定资产的销售
  • 清理缓存网页电脑
  • 财务报表包括哪几个表
  • 交了预付款后,一方违约怎么处理
  • 商业承兑汇票到期兑现流程
  • 哪些情况下可以终止心肺复苏
  • 货没到申请退款玩付邮费吗
  • 公司资质办理费用
  • 电脑显示器模糊不清晰是什么原因
  • 苹果macOS 13.3 RC 发河北承德市承德县华夏电器
  • 现金流量套期的例子
  • 其他应付款的会计分录怎么写
  • 出口退税会计分录怎么做没退到税全部减免抵
  • 混合销售会计处理
  • 甲供材料增值税
  • php批量删除操作记录
  • typescript4.1
  • 新星计划会限流吗
  • 小微企业认定标准时间
  • 前端 大前端
  • php面试基础题
  • pycharm操作界面
  • 装修费用一次性计入成本
  • 预收的贷方余额表示什么
  • 小规模纳税人差额征收税率是多少
  • 应收票据和其他应收款的区别
  • 清算机构收单机构和发卡行
  • 企业收到海河工厂发运的乙材料,并验收入库
  • 垃圾处理费申报怎么填
  • 单位买的空调计入什么科目
  • 三证合一指的是什么意思
  • 企业小汽车折旧年限
  • 电影剧本稿费多少
  • 购买的税控设备
  • 营业收入包括主营业务收入
  • 银行流水账单怎么删
  • 子公司和区域公司的区别
  • 安全生产费计提和使用
  • sql server233错误
  • mysql保存命令
  • 鼠标系统怎么安装
  • ubuntu20.10
  • cmos电池没电会有什么故障现象
  • win10网卡驱动不正常连不上网怎么办
  • jquery添加图片
  • ml命令
  • 在文本输入框中的输入内容是
  • jquery中的选择器有哪些
  • android fragmentation
  • 云南省税务局电话
  • 货物无偿赠予政府怎么写
  • 税务报道是干什么
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设