位置: 编程技术 - 正文

Python实现以时间换空间的缓存替换算法

编辑:rootadmin

推荐整理分享Python实现以时间换空间的缓存替换算法,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

缓存是指可以进行高速数据交换的存储器,它先于内存与CPU交换数据,因此速度很快。缓存就是把一些数据暂时存放于某些地方,可能是内存,也有可能硬盘。

在使用Scrapy爬网站的时候,产生出来的附加产物,因为在Scrapy爬取的时候,CPU的运行时间紧迫度不高(访问频次太高容易被封禁),借此机会难得来上一下,让自己的内存解放一下。

算法原理:

通过将要缓存的数据用二进制展开,得到的二进制数据映射到缓存字段上,要检验是否已经缓存过,仅需要去查找对应的映射位置即可,如果全部匹配上,则已经缓存。

# 二进制就是个二叉树# 如下面可以表示出来的数据有0, 1, 2, 3四个(两个树独立)

0 1/ / 0 1 0 1

因此对缓存的操作就转化为对二叉树的操作,添加和查找只要在二叉树上找到对应路径的node即可。

算法关键代码:

实际使用效果如何呢&#;

Python实现以时间换空间的缓存替换算法

在和Python默认的 set 相比较,得出测试结果如下(存取整型,不定长字符串,定长字符串):

测试下来,内存消耗控制的比较好,一直在字节,而是用 set 的内存虽然也不是很大,当相较于 ByteCache 来说,则大上很多。

但 ByteCache 的方式来缓存,最大的问题是当碰到非常大的随机数据时,消耗时间会比较惊人。如下面这种随机长度的字符串缓存测试结果:

在个数据中,添加消耗s,查找消耗s,而 set 接近于0,单条数据也需要ms(均值)才能完成读/写操作。

不过,正如开头说的,在紧迫度不是很高的Scrapy中,这个时间并不会太过于窘迫,更何况在Scrapy中,一般是用来缓存哈希后的数据,这些数据的一个重要特性是定长,定长在本缓存算法中还是表现不错的,在位长度的时候,均值才0.5ms。而与此同时倒是能在大量缓存的时候,释放出比较客观的内存。

如果有更好的缓存算法能让速度在上新台阶,也是无比期待的。。。

总结:

1. 此方法的目标是用时间换取空间,切勿在时间紧迫度高的地方使用

2. 非常适用于大量定长,且数据本身比较小的情况下使用

3. 接2,非常不建议在大量不定长的数据,而且数据本身比较大的情况下使用

以上内容是小编给大家介绍的Python实现以时间换空间的缓存替换算法,希望对大家有所帮助!

Python中使用OpenCV库来进行简单的气象学遥感影像计算 OpenCV的全称是OpenSourceComputerVisionLibrary,是一个跨平台的计算机视觉库。OpenCV是由英特尔公司发起并参与开发,以BSD许可证授权发行,可以在商业和研究

使用C#配合ArcGIS Engine进行地理信息系统开发 简单的地图读取、展示终于到暑假了。。。开始认真整理整理相关学习的心得体会咯~先把很久之前挖的关于C#二次开发的坑给填上好了~这次先计划用一

Go语言基于Socket编写服务器端与客户端通信的实例 在golang中,网络协议已经被封装的非常完好了,想要写一个Socket的Server,我们并不用像其他语言那样需要为socket、bind、listen、receive等一系列操作头疼,

标签: Python实现以时间换空间的缓存替换算法

本文链接地址:https://www.jiuchutong.com/biancheng/382378.html 转载请保留说明!

上一篇:Python使用爬虫猜密码(pythone爬虫)

下一篇:Python中使用OpenCV库来进行简单的气象学遥感影像计算(python的opencv)

  • 递延所得税资产和负债怎么理解
  • 餐饮业厨房设备专票可以抵税吗
  • 汽车运输企业付给车主的运费算成本吗
  • 技术服务费入账
  • 邮局可以开发票吗 税点多少
  • 当期计提加计抵减额如何确定
  • 人力资源服务费发票可以抵扣吗
  • 房产税从租计征12%是年税率吗
  • 新的企业所得税暂行条例
  • 用友软件销售操作流程
  • 用银行存款支付罚款
  • 个税手续费返还政策最新规定2023
  • 影视发行收入该如何做税收处理?
  • 车辆一次性入费用会计分录
  • 当月冲红发票会导致上月发票作废吗?
  • 农村合作社开的鸡蛋免税票可以抵进项税吗?
  • 高温补贴需要交个人所得税吗2019
  • 分期付款确认收入借方写啥
  • 跨期费用审计调整分录
  • win10下载软件被阻止安装怎么办
  • 工业企业增值税负率一般控制在多少
  • 预付账款是负数有什么税收风险
  • 普通发票的进项票怎么做分录
  • 苹果系统的声音
  • nvidia gpu系列
  • 程序员中秋节祝福语
  • 为什么要把收入当成舞弊假定
  • 企业雇佣临时工个税
  • thinkphpcount查询
  • html导航栏边框
  • 讯飞智能x2
  • 个人独资企业如何做账
  • 核心书评价格
  • 【C#+JavaScript+SQL Server】实现Web端考试系统 六:后台管理模块设计(附源码和资源)
  • win11系统中怎样调整office底色
  • python连接网络
  • python如何在画布上写字
  • 结算业务书汇票怎么写
  • 公允价值变动损益影响利润总额吗
  • 向境外股东分配股息预提所得税
  • 租金收入如何确认收入
  • 劳务分包属于人工成本吗
  • 企业工会经费计提比例
  • sql函数coalesce
  • 三免三减半如何申报
  • 免征水利建设基金条件
  • 固定资产特点有
  • 固定资产入账怎么做凭证和入资产卡片?
  • 生产辅料清单
  • 建筑公司工程按什么收费
  • 标的编制费
  • 债权投资有哪些科目
  • 钱汇错了报警有用吗
  • 联营企业和子公司哪个好
  • mysql更改密码命令
  • Windows10下mysql 5.7.17 安装配置方法图文教程
  • win8系统开机直接进入桌面
  • winxp怎么打印
  • linux日志类型
  • ubuntu 125%
  • macbookair文档怎么变成word
  • win10 2020h1
  • linux修改时间和日期的方法
  • unity特效制作教程
  • easyui datagrid resize
  • express.json()
  • shell脚本tr
  • Node.js中的包管理工具是什么
  • 安卓安全警告怎么关闭
  • fiori开发
  • JavaScript+html5 canvas制作的圆中圆效果实例
  • typescript concat
  • android webview webgl
  • 民办非企业单位登记管理暂行条例
  • 增值税消费税申报比对不符怎么办
  • 新疆税务局网站官网首页
  • 怎么注册山东省采购网
  • 落实措施对吗
  • 2010年末实现净利润390万,宣告发放现金股利40万,在计算本年未分配利润时,是否要减掉这40万?
  • 税收筹划六种方法
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设