Sobes.tech
Назад к вопросам
Junior — Middle
80

Можешь привести пример подхода к организации кэширования данных в системе?

Ответ от нейросети

sobes.tech AI

В Go для организации кэширования данных часто используют встроенные структуры данных, например, map с дополнительной логикой для управления временем жизни кэша (TTL). Один из простых подходов — создать структуру, которая хранит данные и время их создания, и при запросе проверять, не устарели ли данные.

Пример простого кэша с TTL:

package main

import (
    "fmt"
    "sync"
    "time"
)

type cacheItem struct {
    value      interface{}
    expiration time.Time
}

type Cache struct {
    items map[string]cacheItem
    mu    sync.RWMutex
    ttl   time.Duration
}

func NewCache(ttl time.Duration) *Cache {
    return &Cache{
        items: make(map[string]cacheItem),
        ttl:   ttl,
    }
}

func (c *Cache) Set(key string, value interface{}) {
    c.mu.Lock()
    defer c.mu.Unlock()
    c.items[key] = cacheItem{
        value:      value,
        expiration: time.Now().Add(c.ttl),
    }
}

func (c *Cache) Get(key string) (interface{}, bool) {
    c.mu.RLock()
    defer c.mu.RUnlock()
    item, found := c.items[key]
    if !found || time.Now().After(item.expiration) {
        return nil, false
    }
    return item.value, true
}

func main() {
    cache := NewCache(5 * time.Minute)
    cache.Set("user_1", "John Doe")

    if val, ok := cache.Get("user_1"); ok {
        fmt.Println("Cached value:", val)
    } else {
        fmt.Println("Value not found or expired")
    }
}

Такой подход подходит для простых случаев. Для более сложных систем используют специализированные библиотеки или внешние кэши (Redis, Memcached).