Skip to content

keenan-v1/johnnycache

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

16 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

johnnycache

Go Report Card GoDoc Build Status Coverage Status

Simple cache implementations for Go

  • Expiry - A string, interface{} concurrent expiring cache

Getting Started

go get -u github.com/keenan-v1/johnnycache/expiry

import "github.com/keenan-v1/johnnycache/expiry"

Example

package main

import (
	"time"
	"fmt"
	"github.com/keenan-v1/johnnycache/expiry"
)

func main() {
	c := expiry.New()
	c.Store("key", "Johnny Cache", time.Minute) // Store the value
	v, ok := c.LoadAsString("key") // LoadAsString performs type-checking for you
	if ok {
		fmt.Println(v)
	}
	// Output: Johnny Cache

	c = expiry.New()
	for i := 0; i < 1000; i++ {
		c.Store(fmt.Sprintf("key %d", i), fmt.Sprintf("value %d", i), time.Nanosecond)
	}
	time.Sleep(time.Nanosecond + 1)
	// Expired elements are only removed when an attempt to load occurs or a Sweep() is called
	fmt.Println(c.Count())

	// Since the life span was set to a nanosecond, these elements should be expired now and Load will return false
	_, ok = c.Load("key 1")
	if !ok {
		fmt.Println("expired")
	}
	fmt.Println(c.Count())

	// Sweep can be called directly, or passed to a goroutine for background sweeping
	c.Sweep()
	fmt.Println(c.Count())

	// Output:
	// 1000
	// expired
	// 999
	// 0

}

About

Simple Golang caches

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages