mirror of
https://codeberg.org/superseriousbusiness/gotosocial.git
synced 2025-01-12 03:07:22 +03:00
55 lines
1.3 KiB
Markdown
55 lines
1.3 KiB
Markdown
|
# SwissMap
|
||
|
|
||
|
SwissMap is a hash table adapated from the "SwissTable" family of hash tables from [Abseil](https://abseil.io/blog/20180927-swisstables). It uses [AES](https://github.com/dolthub/maphash) instructions for fast-hashing and performs key lookups in parallel using [SSE](https://en.wikipedia.org/wiki/Streaming_SIMD_Extensions) instructions. Because of these optimizations, SwissMap is faster and more memory efficient than Golang's built-in `map`. If you'd like to learn more about its design and implementation, check out this [blog post](https://www.dolthub.com/blog/2023-03-28-swiss-map/) announcing its release.
|
||
|
|
||
|
|
||
|
## Example
|
||
|
|
||
|
SwissMap exposes the same interface as the built-in `map`. Give it a try using this [Go playground](https://go.dev/play/p/JPDC5WhYN7g).
|
||
|
|
||
|
```go
|
||
|
package main
|
||
|
|
||
|
import "github.com/dolthub/swiss"
|
||
|
|
||
|
func main() {
|
||
|
m := swiss.NewMap[string, int](42)
|
||
|
|
||
|
m.Put("foo", 1)
|
||
|
m.Put("bar", 2)
|
||
|
|
||
|
m.Iter(func(k string, v int) (stop bool) {
|
||
|
println("iter", k, v)
|
||
|
return false // continue
|
||
|
})
|
||
|
|
||
|
if x, ok := m.Get("foo"); ok {
|
||
|
println(x)
|
||
|
}
|
||
|
if m.Has("bar") {
|
||
|
x, _ := m.Get("bar")
|
||
|
println(x)
|
||
|
}
|
||
|
|
||
|
m.Put("foo", -1)
|
||
|
m.Delete("bar")
|
||
|
|
||
|
if x, ok := m.Get("foo"); ok {
|
||
|
println(x)
|
||
|
}
|
||
|
if m.Has("bar") {
|
||
|
x, _ := m.Get("bar")
|
||
|
println(x)
|
||
|
}
|
||
|
|
||
|
m.Clear()
|
||
|
|
||
|
// Output:
|
||
|
// iter foo 1
|
||
|
// iter bar 2
|
||
|
// 1
|
||
|
// 2
|
||
|
// -1
|
||
|
}
|
||
|
```
|