用map可实现轻量级内存缓存,但需封装结构体添加并发安全、TTL过期、容量限制和命中统计;推荐惰性检查+定时清理过期项,高并发场景可选sync.Map或go-cache等成熟库。
Go 语言中,map 是最直接的键值存储结构,适合实现轻量级内存缓存。例如:
var cache = make(map[string]interface{})
cache["user:1001"] = User{Name: "Alice", Age: 30}
if val, ok := cache["user:1001"]; ok { ... }
delete(cache, "user:1001")
这种方式零依赖、启动快,但缺点明显:不支持自动过期、无并发安全、无法统计命中率、不能限制容量。
把 map 包进自定义结构体,可系统性补足短板。典型字段包括:
map[string]cacheEntry
sync.RWMutex,读多写少场景下提升并发性能sync/atomic),用于监控示例核心方法:Get(key string) (interface{}, bool) 先加读锁查 map;Set(key string, value interface{}, ttl time.Duration) 加写锁写入并记录过期时间。
真正实用的缓存必须处理数据时效性。推荐“惰性+定时清理”组合:
type cacheEntry struct { Value interface{}; ExpiredAt time.Time }
time.Now().Before(entry.ExpiredAt),过期则返回未命中并自动清理(可选)cleanExpired() 删除陈旧项——避免每次 Get 都遍历全量不建议用 time.AfterFunc 为每个 key 单独设 timer,高并发下易导致 goroutine 泛滥和内存泄漏。
当读写比极高(如 > 90% 读)、key 数量大且更新分散时,原生 map + RWMutex 可能成瓶颈。此时可考虑:
sync.Map:免锁、适合只读频繁+写入稀疏的场景,但不支持遍历和 size 统计
片 + 内存池减少 GC 压力自研缓存重在理解原理;生产环境优先评估维护成本与稳定性,再决定是否造轮子。