Skip to content

vadiminshakov/partmap

Repository files navigation

Simple and fast thread-safe partitioned map

Faster then writing to std map.

Project motivation

go test -bench=. -benchtime=3s

goos: darwin
goarch: amd64
pkg: github.com/vadimInshakov/partmap
cpu: Intel(R) Core(TM) i7-9750H CPU @ 2.60GHz

BenchmarkStd/set_std_concurrently-12                  3289076   1332 ns/op
BenchmarkSyncStd/set_sync_map_std_concurrently-12     2408612   1691 ns/op
BenchmarkPartitioned/set_partitioned_concurrently-12  13536134  408.6 ns/op <-

Usage:

m := partmap.NewPartitionedMapWithDefaultPartitioner(3, 10) // 3 partitions, 10 map size

if err := m.Set("key", 123); err != nil {
    panic(err)
}

value, err := m.Get("key")
if err != nil && !errors.Is(err, partmap.ErrNotFound) {
    panic(err)
}

println(value) // 123

if err := m.Del("key"); err != nil {
    panic(err)
}

https://pkg.go.dev/github.com/vadiminshakov/partmap

About

partitioned map for write heavy workloads

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages