Sobes.tech
Back to questions
Junior — Middle
85

Можно объяснить принцип работы LRU-кеша и в каких ситуациях он применяется?

Answer from AI

sobes.tech AI

LRU (Least Recently Used) кеш — это структура данных, которая хранит ограниченное количество элементов и при переполнении удаляет самый давно неиспользуемый элемент.

Принцип работы:

  • При обращении к элементу он становится самым "свежим".
  • Если кеш заполнен и нужно добавить новый элемент, удаляется элемент, к которому не обращались дольше всего.

Это позволяет эффективно использовать память, сохраняя наиболее актуальные данные.

Применение:

  • Кеширование результатов запросов к базе данных.
  • Кеширование изображений или файлов в памяти.
  • В системах с ограниченными ресурсами для оптимизации доступа к данным.

Пример на Go (упрощённый):

// Используем контейнер list для хранения порядка использования
import (
    "container/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, 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
}