EvictCallback is used to get a callback when a cache entry is evicted
type EvictCallback func(key interface{}, value interface{})
LRU implements a non-thread safe fixed size LRU cache
type LRU struct {
// contains filtered or unexported fields
}
func NewLRU(size int, onEvict EvictCallback) (*LRU, error)
NewLRU constructs an LRU of the given size
func (c *LRU) Add(key, value interface{}) (evicted bool)
Add adds a value to the cache. Returns true if an eviction occurred.
func (c *LRU) Contains(key interface{}) (ok bool)
Contains checks if a key is in the cache, without updating the recent-ness or deleting it for being stale.
func (c *LRU) Get(key interface{}) (value interface{}, ok bool)
Get looks up a key's value from the cache.
func (c *LRU) GetOldest() (key, value interface{}, ok bool)
GetOldest returns the oldest entry
func (c *LRU) Keys() []interface{}
Keys returns a slice of the keys in the cache, from oldest to newest.
func (c *LRU) Len() int
Len returns the number of items in the cache.
func (c *LRU) Peek(key interface{}) (value interface{}, ok bool)
Peek returns the key value (or undefined if not found) without updating the "recently used"-ness of the key.
func (c *LRU) Purge()
Purge is used to completely clear the cache.
func (c *LRU) Remove(key interface{}) (present bool)
Remove removes the provided key from the cache, returning if the key was contained.
func (c *LRU) RemoveOldest() (key, value interface{}, ok bool)
RemoveOldest removes the oldest item from the cache.
func (c *LRU) Resize(size int) (evicted int)
Resize changes the cache size.
LRUCache is the interface for simple LRU cache.
type LRUCache interface { // Adds a value to the cache, returns true if an eviction occurred and // updates the "recently used"-ness of the key. Add(key, value interface{}) bool // Returns key's value from the cache and // updates the "recently used"-ness of the key. #value, isFound Get(key interface{}) (value interface{}, ok bool) // Checks if a key exists in cache without updating the recent-ness. Contains(key interface{}) (ok bool) // Returns key's value without updating the "recently used"-ness of the key. Peek(key interface{}) (value interface{}, ok bool) // Removes a key from the cache. Remove(key interface{}) bool // Removes the oldest entry from cache. RemoveOldest() (interface{}, interface{}, bool) // Returns the oldest entry from the cache. #key, value, isFound GetOldest() (interface{}, interface{}, bool) // Returns a slice of the keys in the cache, from oldest to newest. Keys() []interface{} // Returns the number of items in the cache. Len() int // Clears all cache entries. Purge() // Resizes cache, returning number evicted Resize(int) int }