d2/lib/syncmap/syncmap.go

41 lines
690 B
Go
Raw Normal View History

2023-10-30 19:02:29 +00:00
package syncmap
import "sync"
type SyncMap[K comparable, V any] struct {
_map *sync.Map
}
func New[K comparable, V any]() SyncMap[K, V] {
return SyncMap[K, V]{
_map: &sync.Map{},
}
}
func (sm SyncMap[K, V]) Set(key K, value V) {
sm._map.Store(key, value)
}
2023-10-30 20:51:36 +00:00
func (sm SyncMap[K, V]) Get(key K) (value V, ok bool) {
2023-10-30 19:02:29 +00:00
v, has := sm._map.Load(key)
if !has {
return value, false
}
return v.(V), true
}
2023-10-30 20:51:36 +00:00
func (sm SyncMap[K, V]) MustGet(key K) (value V) {
v, _ := sm.Get(key)
2023-10-30 19:02:29 +00:00
return v
}
func (sm SyncMap[K, V]) Delete(key K) {
sm._map.Delete(key)
}
func (sm SyncMap[K, V]) Range(f func(key K, value V) bool) {
sm._map.Range(func(k, v any) bool {
return f(k.(K), v.(V))
})
}