位置: 编程技术 - 正文

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)

  • 小规模纳税人所得税优惠政策2023
  • 转让不动产账务处理
  • 累计折旧贷方余额表示
  • 融资租赁租出的固定资产需要计提折旧吗
  • 生产成本科目期末余额反映的是
  • 员工辞退补偿金需要交个税吗
  • 固定资产升值可以入账吗?
  • 如何确定核定征收的应税所得率
  • 计提递延所得税资产
  • 拆迁房视同销售成本可以抵减吗?
  • 去年增值税销项少2元
  • 航天服务费手写发票可以抵减吗?
  • 物业公司小规模纳税人如何报税
  • 增值税又有调整政策吗
  • 公司清算补偿工资标准
  • 现金折扣发票如何开具
  • 承兑贴息收入账务处理怎么做?
  • 福利费专票进项转出怎么做账
  • 自己种的苗木开发票要什么手续
  • 月末利润分配的账务处理
  • 分支机构能否核定企业所得税
  • 企业社会贡献总结怎么写
  • 打开我的电脑出现找不到应用程序
  • 空调安装费计入什么科目
  • 文件夹如何更改图标
  • linux怎么开启远程
  • linux系统怎么更改主机名
  • 科技研发公司经营范围包括哪些
  • 销售二手车减免税额会计分录
  • ’sass_binary_site‘ is not a valid npm option问题的产生原因及解决办法
  • 个人投资额是什么意思
  • 固定资产改扩建账务处理
  • 孕妇能吃荔枝吗 孕晚期
  • 设置浏览器显示网络异常
  • 期间费用转入本年利润
  • 低值易耗品的三级科目有哪些
  • Laravel5.* 打印出执行的sql语句的方法
  • vue打包成一个文件
  • 水利建设基金的计税依据及税率
  • framework3.5启用
  • 【综述】分子预训练模型综述
  • vue2计算属性和vue3的计算属性的区别
  • 阿里巴巴达摩院ai
  • is-l命令
  • 三代手续费返还是否需要缴纳增值税
  • 修改Dede默认投票代码 防止Request Error错误
  • sql server查询前1000条纪录
  • 应交增值税账面余额与报税余额不符
  • 购买服务费用
  • 固定资产清理损益表怎么填
  • 进口关税,增值税是进口设备重置成本中的从属费用
  • 增值税专用发票丢了怎么补救
  • 小规模纳税人财务报表季报怎么填
  • 委托加工产品送货合同
  • 外币财务报表的折算
  • 电脑折旧多少钱
  • win2000服务器
  • xp系统弹出帮助和支持
  • windows自带安全
  • auepuc.exe是什么软件
  • win8分屏快捷键
  • 命令行教程
  • windows8使用教程
  • 如何检测装有监控器?
  • 建立一个新用户并把它加入wheel组,设置用户密码为123
  • linux rpm解压
  • css的基础
  • jquery 插件写法
  • js nextSibling属性和previousSibling属性概述及使用注意
  • jquery遍历li
  • 配置ip地址的方法有哪几种
  • python将结果写入excel
  • a标签跳转本地html页面
  • javascript delete 使用示例代码
  • unity3d游戏开发书籍
  • 基于JAVASCRIPT实现的可视化工具是
  • flask框架数据可视化
  • 泉州国税局网站首页
  • 湖南省税务举报
  • 税收筹划可分为
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设