Назад к вопросам
Senior
5
Как было реализовано кэширование данных? Какая политика кэширования использовалась?
Компании, где спрашивали
Lenta Tech
Ответ от нейросети
sobes.tech AI
Кэширование данных обычно реализуется с помощью структуры данных, которая хранит недавно или часто используемые объекты для быстрого доступа.
Политика кэширования зависит от задачи, но часто используются:
- LRU (Least Recently Used) — удаляются наименее недавно использованные элементы.
- LFU (Least Frequently Used) — удаляются наименее часто используемые.
- TTL (Time To Live) — элементы удаляются после определённого времени.
В Go для кэширования можно использовать map с дополнительной логикой для политики удаления, либо готовые библиотеки (например, groupcache или ristretto).
Пример простого LRU-кэша с использованием контейнера list:
import (
"container/list"
"sync"
)
type CacheItem struct {
key string
value interface{}
}
type LRUCache struct {
capacity int
cache map[string]*list.Element
list *list.List
mu sync.Mutex
}
func NewLRUCache(cap int) *LRUCache {
return &LRUCache{
capacity: cap,
cache: make(map[string]*list.Element),
list: list.New(),
}
}
func (c *LRUCache) Get(key string) (interface{}, bool) {
c.mu.Lock()
defer c.mu.Unlock()
if elem, ok := c.cache[key]; ok {
c.list.MoveToFront(elem)
return elem.Value.(*CacheItem).value, true
}
return nil, false
}
func (c *LRUCache) Put(key string, value interface{}) {
c.mu.Lock()
defer c.mu.Unlock()
if elem, ok := c.cache[key]; ok {
c.list.MoveToFront(elem)
elem.Value.(*CacheItem).value = value
return
}
if c.list.Len() == c.capacity {
back := c.list.Back()
if back != nil {
c.list.Remove(back)
delete(c.cache, back.Value.(*CacheItem).key)
}
}
item := &CacheItem{key, value}
elem := c.list.PushFront(item)
c.cache[key] = elem
}