zl程序教程

您现在的位置是:首页 >  其他

当前栏目

「Go工具箱」一个基于双向链表实现的LRU缓存工具

2023-02-26 09:48:42 时间

大家好,我是渔夫子。本号新推出「go工具箱」系列,意在给大家分享使用go语言编写的、实用的、好玩的工具。

今天给大家推荐的工具是一个实现了固定缓存大小、线程安全的缓存组件,该缓存实现了最近最少使用的策略:golang-lru。

实现原理分析:该包是基于内置包 list.List实现的,list.List的底层是一个双向链接。并提供了一个列表的大小。当对该列表中的某个元素进行访问或添加操作时,就将该元素移动到链表的最前面。当新添加元素后,元素数量超过了列表的大小,则将最后一个元素移除。

该包使用起来也很简单,首先给缓存设置一个容量大小,然后就可以对元素进行添加和删除了,如果缓存中超过了128个元素,在操作的同时就会把最近没有使用的元素给删除掉。如下:

cache, _ := lru.New(128)
// 往缓存中添加一个key-value
cache.Add("age", 19)
// 获取缓存中的key的value
cache.Get("age")
// 移除缓存中的key
cache.Remove("age")
//获取缓存中元素的个数
cache.Len()

更多项目详情请查看如下链接。

开源项目地址:https://github.com/hashicorp/golang-lru

开源项目作者:hashicorp

---特别推荐---

特别推荐:一个专注go项目实战、项目中踩坑经验及避坑指南、各种好玩的go工具的公众号,「Go学堂」,专注实用性,非常值得大家关注。点击下方公众号卡片,直接关注。关注送《100个go常见的错误》pdf文档。