...

Package simplelru

import "github.com/hashicorp/golang-lru/v2/simplelru"
Overview
Index

Overview ▾

Package simplelru provides simple LRU implementation based on build-in container/list.

type EvictCallback

EvictCallback is used to get a callback when a cache entry is evicted

type EvictCallback[K comparable, V any] func(key K, value V)

type LRU

LRU implements a non-thread safe fixed size LRU cache

type LRU[K comparable, V any] struct {
    // contains filtered or unexported fields
}

func NewLRU

func NewLRU[K comparable, V any](size int, onEvict EvictCallback[K, V]) (*LRU[K, V], error)

NewLRU constructs an LRU of the given size

func (*LRU[K, V]) Add

func (c *LRU[K, V]) Add(key K, value V) (evicted bool)

Add adds a value to the cache. Returns true if an eviction occurred.

func (*LRU[K, V]) Contains

func (c *LRU[K, V]) Contains(key K) (ok bool)

Contains checks if a key is in the cache, without updating the recent-ness or deleting it for being stale.

func (*LRU[K, V]) Get

func (c *LRU[K, V]) Get(key K) (value V, ok bool)

Get looks up a key's value from the cache.

func (*LRU[K, V]) GetOldest

func (c *LRU[K, V]) GetOldest() (key K, value V, ok bool)

GetOldest returns the oldest entry

func (*LRU[K, V]) Keys

func (c *LRU[K, V]) Keys() []K

Keys returns a slice of the keys in the cache, from oldest to newest.

func (*LRU[K, V]) Len

func (c *LRU[K, V]) Len() int

Len returns the number of items in the cache.

func (*LRU[K, V]) Peek

func (c *LRU[K, V]) Peek(key K) (value V, ok bool)

Peek returns the key value (or undefined if not found) without updating the "recently used"-ness of the key.

func (*LRU[K, V]) Purge

func (c *LRU[K, V]) Purge()

Purge is used to completely clear the cache.

func (*LRU[K, V]) Remove

func (c *LRU[K, V]) Remove(key K) (present bool)

Remove removes the provided key from the cache, returning if the key was contained.

func (*LRU[K, V]) RemoveOldest

func (c *LRU[K, V]) RemoveOldest() (key K, value V, ok bool)

RemoveOldest removes the oldest item from the cache.

func (*LRU[K, V]) Resize

func (c *LRU[K, V]) Resize(size int) (evicted int)

Resize changes the cache size.

func (*LRU[K, V]) Values

func (c *LRU[K, V]) Values() []V

Values returns a slice of the values in the cache, from oldest to newest.

type LRUCache

LRUCache is the interface for simple LRU cache.

type LRUCache[K comparable, V any] interface {
    // Adds a value to the cache, returns true if an eviction occurred and
    // updates the "recently used"-ness of the key.
    Add(key K, value V) bool

    // Returns key's value from the cache and
    // updates the "recently used"-ness of the key. #value, isFound
    Get(key K) (value V, ok bool)

    // Checks if a key exists in cache without updating the recent-ness.
    Contains(key K) (ok bool)

    // Returns key's value without updating the "recently used"-ness of the key.
    Peek(key K) (value V, ok bool)

    // Removes a key from the cache.
    Remove(key K) bool

    // Removes the oldest entry from cache.
    RemoveOldest() (K, V, bool)

    // Returns the oldest entry from the cache. #key, value, isFound
    GetOldest() (K, V, bool)

    // Returns a slice of the keys in the cache, from oldest to newest.
    Keys() []K

    // Values returns a slice of the values in the cache, from oldest to newest.
    Values() []V

    // Returns the number of items in the cache.
    Len() int

    // Clears all cache entries.
    Purge()

    // Resizes cache, returning number evicted
    Resize(int) int
}