2025-07-25 03:15:45 +00:00
|
|
|
|
package utils
|
|
|
|
|
|
|
|
|
|
|
|
import (
|
2025-07-25 06:22:16 +00:00
|
|
|
|
"sync"
|
2025-07-25 03:15:45 +00:00
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
// 定义一个泛型的 SyncMap,支持任意类型的键和值
|
|
|
|
|
|
type SyncMap[K comparable, V any] struct {
|
2025-07-25 06:22:16 +00:00
|
|
|
|
m sync.Map
|
2025-07-25 03:15:45 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// 设置键值对
|
|
|
|
|
|
func (sm *SyncMap[K, V]) Store(key K, value V) {
|
2025-07-25 06:22:16 +00:00
|
|
|
|
sm.m.Store(key, value)
|
|
|
|
|
|
}
|
|
|
|
|
|
func (sm *SyncMap[K, V]) LoadOrStore(key K, value V) (V, bool) {
|
|
|
|
|
|
val, ok := sm.m.LoadOrStore(key, value)
|
|
|
|
|
|
return val.(V), ok
|
|
|
|
|
|
|
2025-07-25 03:15:45 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// 获取键对应的值
|
|
|
|
|
|
func (sm *SyncMap[K, V]) Load(key K) (V, bool) {
|
2025-07-25 06:22:16 +00:00
|
|
|
|
val, ok := sm.m.Load(key)
|
|
|
|
|
|
if ok {
|
|
|
|
|
|
return val.(V), true
|
|
|
|
|
|
}
|
|
|
|
|
|
var zeroValue V
|
|
|
|
|
|
return zeroValue, false
|
2025-07-25 03:15:45 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// 删除键值对
|
|
|
|
|
|
func (sm *SyncMap[K, V]) Delete(key K) {
|
2025-07-25 06:22:16 +00:00
|
|
|
|
sm.m.Delete(key)
|
2025-07-25 03:15:45 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// 遍历所有键值对
|
|
|
|
|
|
func (sm *SyncMap[K, V]) Range(f func(key K, value V) bool) {
|
2025-07-25 06:22:16 +00:00
|
|
|
|
sm.m.Range(func(key, value any) bool {
|
|
|
|
|
|
return f(key.(K), value.(V))
|
|
|
|
|
|
})
|
2025-07-25 03:15:45 +00:00
|
|
|
|
}
|