位置: 编程技术 - 正文

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年
  • 个人所得税一般多久能退下来
  • 个人独资企业出资额是注册资本吗
  • 出口托收业务
  • 印花税已经申报在哪里点交费
  • 企业所得税计提分录
  • 税控盘怎么增加专票
  • 房地产企业营改增前都交那些税
  • 股权投资基金账户有监管吗
  • 事业单位之间调动需要多久
  • 异地预交所得税跨年还能用吗
  • 什么时候需要计提税金及附加
  • 申请一般纳税人需要多长时间
  • 土地增值税清算的条件
  • 国家税务总局2011年第25号公告
  • 收回债权会计分录
  • 桌面图标变成了一张纸
  • linux使用docker
  • 投资收益借贷方向增减
  • PHP:Memcached::prependByKey()的用法_Memcached类
  • 销项负数发票怎么处理
  • nerosmartstart.exe - nerosmartstart是什么进程 作用是什么
  • 个人补缴的养老全部划入个人账户
  • php time
  • uniapp控制硬件设备
  • pc端微信扫码支付
  • php trait用法
  • 月底资产负债表不平怎么找原因
  • laravel框架实现cms的体会
  • 社保基数跟个税差1仟多有风险吗
  • 其他收益会计科目怎么写
  • 21年前端面试题
  • js怎么制作
  • 时间序列模型ARIMA的优缺点
  • 发票作废冲红怎么做账
  • 销售服饰
  • java中同步
  • 一般纳税人增值税优惠政策2023
  • 固定资产未转固属于什么问题
  • 城镇土地使用税怎么算
  • 去年的亏损今年第一季度可以弥补吗
  • 结转本年利润按什么算
  • 低值易耗品一次性摊销会计科目
  • 没有收入有支出怎么处理账务
  • 利润是用含税价还是去税价
  • 企业投资期货亏损能抵税么
  • 与成本直接相关的有哪些
  • 计提坏账准备不属于企业的或有事项
  • 二级分支机构不具有主体生产经营职能?
  • 选择简易计税方法
  • 社保可以不计提账务处理
  • 抄报返写
  • 《新会计准则》
  • mysql中/g
  • win8的应用商店在哪
  • win8.1关机没反应
  • Windows Server 2008下高效域管理体验
  • win10 mobile下载
  • ubuntu 14.04.6
  • win8系统升级后怎么退回
  • linux几种安装方式
  • mpcmdrun.exe是什么进程
  • win7系统玩游戏卡顿怎么办
  • win7自带截图工具
  • win8系统关机在哪
  • win10系统应用和功能中不能卸载
  • android程序的基本结构
  • shell脚本连接服务器
  • node.js操作文件
  • recycleview使用
  • android颜色代码表
  • Python编程中的逻辑与控制
  • JavaScript Length 属性的总结
  • python怎么用数组
  • js根据name取值
  • jquery给表单赋值
  • jquery?
  • 顺丰快递的开票历史如何删除
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设