前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >用 Go 实现一个 LRU cache

用 Go 实现一个 LRU cache

作者头像
crossoverJie
发布2022-10-27 13:19:03
2530
发布2022-10-27 13:19:03
举报
文章被收录于专栏:crossoverJie

前言

早在几年前写过关于 LRU cache 的文章:https://crossoverjie.top/2018/04/07/algorithm/LRU-cache/

当时是用 Java 实现的,最近我在完善 ptg 时正好需要一个最近最少使用的数据结构来存储历史记录。

ptg: Performance testing tool (Go), 用 Go 实现的 gRPC 客户端调试工具。

Go 官方库中并没有相关的实现,考虑到程序的简洁就不打算依赖第三方库,自己写一个;本身复杂度也不高,没有几行代码。

配合这个数据结构,我便在 ptg 中实现了请求历史记录的功能:

将每次的请求记录存储到 lru cache 中,最近使用到的历史记录排在靠前,同时也能提供相关的搜索功能;具体可见下图。

实现

实现原理没什么好说的,和 Java 的一样:

  • 一个双向链表存储数据的顺序
  • 一个 map 存储最终的数据
  • 当数据达到上限时移除链表尾部数据
  • 将使用到的 Node 移动到链表的头结点

虽然 Go 比较简洁,但好消息是基本的双向链表结构还是具备的。

所以基于此便定义了一个 LruCache:

根据之前的分析:

  • size 存储缓存大小。
  • 链表存储数据顺序。
  • map 存储数据。
  • lock 用于控制并发安全。

接下来重点是两个函数:写入、查询。

写入时判断是否达到容量上限,达到后删除尾部数据;否则就想数据写入头部。

而获取数据时,这会将查询到的结点移动到头结点。

这些结点操作都由 List 封装好了的。

所以使用起来也比较方便。

最终就是通过这个 LruCache 实现了上图的效果,想要了解更多细节的可以参考源码:

https://github.com/crossoverJie/ptg/blob/main/gui/lru.go

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-12-20,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 crossoverJie 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 实现
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档