Sobes.tech
Back to questions
Senior
6

Как было реализовано кэширование данных? Какая политика кэширования использовалась?

Companies where asked
Lenta Tech

Answer from AI

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
}