LRU缓存置换算法如何实现,测试怎样做
Admin 2022-08-19 群英技术资讯 260 次浏览
在第一节中已经实现了双向链表DoubleLinkedList类,本节我们基于双向链表实现LRU(Least Recently Used最近最少使用)缓存置换算法。Redis的淘汰机制就包括LRU算法,用来淘汰那些最近最少使用的数据,具体怎么使用可在redis的配置文件中设置。
逻辑很简单,get和put两种操作,其中get时如果元素存在则将节点从当前位置移到链表头部,表示最近被访问到的节点;put时也是,不管节点之前存不存在都要移动到链表头部。同样通过一个map来实现查找时的O(1)复杂度。
class LRUCache(object): def __init__(self, capacity=0xffffffff): """ LRU缓存置换算法 最近最少使用 :param capacity: """ self.capacity = capacity self.size = 0 self.map = {} self.list = DoubleLinkedList(capacity) def get(self, key): """ 获取元素 获取元素不存在 返回None 获取元素已存在 将节点从当前位置删除并添加至链表头部 :param key: :return: """ # 元素不存在 if key not in self.map: return None node = self.map.get(key) self.list.remove(node) self.list.append_front(node) return node.value def put(self, key, value): """ 添加元素 被添加的元素已存在 更新元素值并已到链表头部 被添加的元素不存在 链表容量达到上限 删除尾部元素 链表容量未达上限 添加至链表头部 :param key: :param value: :return: """ if key in self.map: node = self.map.get(key) node.value = value self.list.remove(node) self.list.append_front(node) else: if self.size >= self.capacity: old_node = self.list.remove() del self.map[old_node.key] self.size -= 1 node = Node(key, value) self.map[key] = node self.list.append_front(node) self.size += 1 return node def print(self): """ 打印当前链表 :return: """ self.list.print()
if __name__ == '__main__': lru_cache = LRUCache(3) lru_cache.put(1, 1) lru_cache.print() lru_cache.put(2, 2) lru_cache.print() print(lru_cache.get(1)) lru_cache.print() lru_cache.put(3, 3) lru_cache.print() lru_cache.put(1, 100) lru_cache.print() lru_cache.put(4, 4) lru_cache.print() print(lru_cache.get(1)) lru_cache.print()
测试结果:
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要为大家介绍了Python字典查找性能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助<BR>
继承用于指定一个类将从其父类获取其大部分或全部功能。 它是面向对象编程的一个特征。 这是一个非常强大的功能,方便用户对现有类进行几个或多个修改来创建一个新的类。新类称为子类或派生类,从其继承属性的主类称为基类或父类。
这篇文章主要介绍了Python NumPy中diag函数的使用说明,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
这篇文章主要介绍了解决pytorch trainloader遇到的多进程问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
这篇文章主要为大家介绍了python数字图像处理使用skimage读取显示与保存图片示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008