大家好!我是一个学习 Go 语言几个月的小菜鸡,最近在学习并发编程的过程中计划开发一个简单的 Go 缓存包。我的最终目标是通过装饰器模式来实现多种缓存模式的支持,并解决缓存异常的问题。
目前已经实现了一个名为 "OSCache" 的模块,它基于 Map 来实现缓存功能。使用起来非常简单,您只需要创建一个 BuildInMapCache 实例,并指定缓存的大小。您可以使用 NewBuildInMapCache 函数来创建实例,例如:
cache := OSCache.NewBuildInMapCache(size)
目前,我已经实现了处理过期时间的三种策略,分别是:
每个键开一个 goroutine 监控删除策略**:您可以使用 NewBuildInMapCacheGos 方法来创建一个支持该策略的缓存实例。
定时轮询策略:我开发了一个支持该策略的缓存实例,您可以使用 NewBuildInMapCacheOneGo 方法来创建,并指定轮询的时间间隔。Done
延迟检查策略:类似于 SQL 连接,在下一次使用时检查缓存条目是否过期。您可以使用 NewBuildInMapCacheNoGO 方法来创建支持该策略的缓存实例。TODO
计划: 实现 RedisCache 模块支持:read-through 、write-through 、cache-aside 、write-back 等模式 如果您对我的项目感兴趣,可以在以下 GitHub 链接中查看我的代码:
https://github.com/wei1bot2tao3/ttCache
欢迎大家提出宝贵的意见和建议,帮助我改进和完善这个缓存包。谢谢!
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.