python之实现缓存环
看了CodeBokk 第二版通过python实现缓存环,吸收之后记录下,方便以后查阅。
任务:
定义一个固定尺寸的缓存,当它填满的时候,新加入的元素会覆盖第一个(最老的)元素。这种数据结构在存储日志和历史信息时非常有用。
解决方案:
当缓存填满时,及时地修改缓存对象,使其从为填满的缓存类变成填满的缓存类。
实现代码如下:
class RingClass:
"""
定义一个未填满的缓存类
"""
def __init__(self, size_max):
self.size = size_max
self.data = [] class __Full:
“”“
定义一个填满缓存时处理
”“”
def append(self, x):
self.data[self.cur] = x
self.cur = (self.cur+1) % self.size def tolist(self):
return self.data[self.cur:]+self.data[:self.cur] def append(self, x):
self.data.append(x)
if len(self.data) == self.size:
self.cur = 0
self.__class__ = self.__Full """永久性的将当前类切换填满的缓存类,关键部分"""
def tolist(self):
return self.data
用法示例代码如下:
if __name__ == "__main__":
x = RingBuff(5)
x.append(1);x.append(2);x.append(3);x.append(4)
print x.__class__,x.tolist()
x.append(5)
print x.__class__,x.tolist()
x.append(6)
print x.__class__, x.data, x.tolist()
x.append(7);x.append(8);x.append(9):x.append(10)
print x.__class__, x.data,x.tolist()
最后的结果示例如下:

由于缓存环有固定大小,当填满的时候,加入新元素会覆盖到它持有的最旧的元素,。通过self.__class__ = self.__Full 完成这个转变。在实际应用中还是很有用处的。记录下,方便以后查阅!
python之实现缓存环的更多相关文章
- 第三百零一节,python操作redis缓存-管道、发布订阅
		python操作redis缓存-管道.发布订阅 一.管道 redis-py默认在执行每次请求都会创建(连接池申请连接)和断开(归还连接池)一次连接操作,如果想要在一次请求中指定多个命令,则可以使用pi ... 
- 第三百节,python操作redis缓存-其他常用操作,用于操作redis里的数据name,不论什么数据类型
		python操作redis缓存-其他常用操作,用于操作redis里的数据name,不论什么数据类型 delete(*names)根据删除redis中的任意数据类型 #!/usr/bin/env pyt ... 
- 第二百九十九节,python操作redis缓存-SortSet有序集合类型,可以理解为有序列表
		python操作redis缓存-SortSet有序集合类型,可以理解为有序列表 有序集合,在集合的基础上,为每元素排序:元素的排序需要根据另外一个值来进行比较,所以,对于有序集合,每一个元素有两个值, ... 
- 第二百九十八节,python操作redis缓存-Set集合类型,可以理解为不能有重复元素的列表
		python操作redis缓存-Set集合类型,可以理解为不能有重复元素的列表 sadd(name,values)name对应的集合中添加元素 #!/usr/bin/env python # -*- ... 
- 第二百九十七节,python操作redis缓存-List类型,可以理解为列表
		python操作redis缓存-List类型,可以理解为列表,是可以有重复元素的列表 List操作,redis中的List在在内存中按照一个name对应一个List来存储.如图: lpush(name ... 
- 第二百九十六节,python操作redis缓存-Hash哈希类型,可以理解为字典类型
		第二百九十六节,python操作redis缓存-Hash哈希类型,可以理解为字典类型 Hash操作,redis中Hash在内存中的存储格式如下图: hset(name, key, value)name ... 
- 第二百九十五节,python操作redis缓存-字符串类型
		python操作redis缓存-字符串类型 首先要安装redis-py模块 python连接redis方式,有两种连接方式,一种是直接连接,一张是通过连接池连接 注意:以后我们都用的连接池方式连接,直 ... 
- python操作Redis缓存
		python操作Redis缓存 https://www.cnblogs.com/guotianbao/p/8683037.html 学习资料:电子书资源 联系邮箱:gmu1592618@gmail.c ... 
- python的数据缓存
		Python的数据缓存 python 的内置数据类型,数值型,字符串,列表,字典等都会有自己的对象缓存池, 这样做的好处是,避免了频繁的申请内存,释放内存,这样会极大的降低应用程序的运行速度,还会造成 ... 
随机推荐
- SZU:B47 Big Integer I
			Judge Info Memory Limit: 32768KB Case Time Limit: 10000MS Time Limit: 10000MS Judger: Normal Descrip ... 
- C#版考题
			某软件大赛C#版考题整理——[单选题] 一.单选题(10小题共20.0分) 1. 以下JavaScript代码的正确输出结果是:(). 1 2 3 4 5 6 7 8 9 <script t ... 
- AngularJS的工作原理
			AngularJS的工作原理 个人觉得,要很好的理解AngularJS的运行机制,才能尽可能避免掉到坑里面去.在这篇文章中,我将根据网上的资料和自己的理解对AngularJS的在启动后,每一步都做了些 ... 
- jQuery中Ajax的应用
			一.Ajax介绍 1.什么是Ajax 异步的JavaScript与XML技术,是一种广泛应用在浏览器的网页开发技术. 2.Ajax的优点 a.不需要任何浏览器插件,在任何支持JavaScript的浏览 ... 
- [转]iOS Tutorial – Dumping the Application Heap from Memory
			Source:https://blog.netspi.com/ios-tutorial-dumping-the-application-heap-from-memory/ An essential ... 
- 一个Shell小脚本——旋转的斜杠
			话不多说,请从代码中寻找乐趣吧! #!/bin/bash #----中断计数器----# incr= #----旋转的斜杠----# spin="/-\|" echo -en &q ... 
- WPF专业编程指南 - DispatcherUnhandledException
			WPF的Application类中有一个事件:DispatcherUnhandledException,在应用程序未对其中的异常加以处理的情况下发生,从而为应用程序把好最后的大门 namespace ... 
- SecureCRT退出全屏方法
			今天在使用SecureCRT的过程中,无意点了全屏,导致SecureCRT连接某台服务器的seesion全屏.后来想退出全屏,SecureCRT没有任何提示,上网查了一下资料说: 退出全屏的命令是AL ... 
- 如何避免误用分布式事务(System.Transactions.TransactionScope)
			以下内容来源与:http://www.cyqdata.com/cyq1162/article-detail-54453 1:本地事务DbTransaction和分布式事务TransactionScop ... 
- cocos2d学习之路四(添加遥控杆)
			添加遥控杆 1. 首先需要再HelloWorldLayer.h中包含ZJoystick.h文件 并且让其实现ZJoystickDelegate协议 2.打开HelloWorldLayer.mm文件实现 ... 
