Sobes.tech
Назад к вопросам
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
}

В этом примере при добавлении нового элемента, если кэш заполнен, удаляется наименее недавно использованный элемент (хвост списка). При доступе к элементу он перемещается в начало списка, что отражает его недавнее использование.