|  |      1scys      2020-03-05 17:33:14 +08:00  1 自己写,两个需求都简单。map 加个锁就行 | 
|  |      2Vegetable      2020-03-05 17:33:55 +08:00  1 sync.Map | 
|  |      3Vegetable      2020-03-05 17:35:19 +08:00 | 
|  |      4guonaihong      2020-03-05 17:48:30 +08:00  2 | 
|      5blackcurrant OP 当达到最大数量或内存时,要能自动删除近期最少使用(LRU)的值。 有现成的库吗?自己写好像有点麻烦。 | 
|  |      6ysmood      2020-03-05 17:54:53 +08:00  1 不知道这个能否满足你的要求 https://github.com/ysmood/umi | 
|      7sunny352787      2020-03-05 17:55:03 +08:00  1 手撸一个 redis ? | 
|  |      8scys      2020-03-05 18:15:46 +08:00 @guonaihong 收了,感谢先,近来可能用上 | 
|  |      9scys      2020-03-05 18:16:36 +08:00 @blackcurrant 做个计算器,然后用 sync.Map ,没入一个对象,重新计算下内存大小。 感觉都是简单的事情,就是包装个 Add/Dell 方法 | 
|      10fordoo      2020-03-05 18:22:51 +08:00  1 | 
|  |      11Muninn      2020-03-05 18:26:55 +08:00  1 小打小闹用 sync.Map 想分布式就麻烦了 自己根据需求挑吧 https://libs.garden/go/search?q=cache&sort=popular | 
|      12zjj19950716      2020-03-05 20:07:58 +08:00 via iPhone  1 groupcache | 
|      13littlewing      2020-03-05 20:27:01 +08:00  1 不考虑用 redis 的原因是啥? | 
|  |      1423571113      2020-03-06 00:28:00 +08:00 via Android LRUCache 很简单,可以做到查找更新都是 log(N)复杂度。 | 
|  |      1523571113      2020-03-06 00:32:40 +08:00 via Android 但是 go 这种"modern"语言居然不支持泛型,所以 cache 也用起来难受。 | 
|  |      16imnaive      2020-03-06 10:07:20 +08:00 建议用读写锁操作含类型的 map,用 sync.map 会丢失类型,每次都要检查类型很麻烦 | 
|      17zichen      2020-03-06 15:38:51 +08:00 本地的话 map 加锁或者 sync.map ,分布式用 redis,有原子操作需求上 lua 脚本。 |