Назад к вопросам
Junior — Middle
73
У вас есть опыт реализации алгоритма кэша с наименее недавно используемыми элементами (LRU)?
Ответ от нейросети
sobes.tech AI
Да, алгоритм кэша с наименее недавно используемыми элементами (LRU) можно реализовать в Go с помощью структуры данных, которая поддерживает быстрый доступ и обновление порядка использования элементов. Обычно для этого используют комбинацию хэш-таблицы и двусвязного списка.
Пример простой реализации LRU-кэша в Go:
package main
import "container/list"
// LRUCache структура кэша
// capacity - максимальный размер
// cache - хэш-таблица для быстрого доступа
// list - двусвязный список для порядка использования
type LRUCache struct {
capacity int
cache map[int]*list.Element
list *list.List
}
type entry struct {
key int
value int
}
func NewLRUCache(capacity int) *LRUCache {
return &LRUCache{
capacity: capacity,
cache: make(map[int]*list.Element),
list: list.New(),
}
}
func (c *LRUCache) Get(key int) (int, bool) {
if elem, ok := c.cache[key]; ok {
c.list.MoveToFront(elem)
return elem.Value.(*entry).value, true
}
return 0, false
}
func (c *LRUCache) Put(key int, value int) {
if elem, ok := c.cache[key]; ok {
c.list.MoveToFront(elem)
elem.Value.(*entry).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.(*entry).key)
}
}
elem := c.list.PushFront(&entry{key, value})
c.cache[key] = elem
}
func main() {
cache := NewLRUCache(2)
cache.Put(1, 1)
cache.Put(2, 2)
val, ok := cache.Get(1) // val=1, ok=true
cache.Put(3, 3) // удалит ключ 2
_, ok2 := cache.Get(2) // ok2=false
_ = val
_ = ok2
}
В этом примере при добавлении нового элемента, если кэш заполнен, удаляется наименее недавно использованный элемент (хвост списка). При доступе к элементу он перемещается в начало списка, что отражает его недавнее использование.