Back to questions
Junior — Middle
81
Можешь привести пример подхода к организации кэширования данных в системе?
Answer from AI
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).