seaweedfs/weed/util/concurrent_read_map.go

61 lines
1.2 KiB
Go
Raw Normal View History

package util
import (
"sync"
)
// A mostly for read map, which can thread-safely
// initialize the map entries.
type ConcurrentReadMap struct {
2016-05-31 03:30:26 +08:00
sync.RWMutex
items map[string]interface{}
}
func NewConcurrentReadMap() *ConcurrentReadMap {
2016-05-31 03:30:26 +08:00
return &ConcurrentReadMap{items: make(map[string]interface{})}
}
func (m *ConcurrentReadMap) initMapEntry(key string, newEntry func() interface{}) (value interface{}) {
2016-05-31 03:30:26 +08:00
m.Lock()
defer m.Unlock()
if value, ok := m.items[key]; ok {
return value
}
value = newEntry()
2016-05-31 03:30:26 +08:00
m.items[key] = value
return value
}
func (m *ConcurrentReadMap) Get(key string, newEntry func() interface{}) interface{} {
2016-05-31 03:30:26 +08:00
m.RLock()
if value, ok := m.items[key]; ok {
m.RUnlock()
return value
}
2016-05-31 03:30:26 +08:00
m.RUnlock()
2015-03-10 15:20:31 +08:00
return m.initMapEntry(key, newEntry)
}
2016-05-31 03:30:26 +08:00
func (m *ConcurrentReadMap) Find(key string) (interface{}, bool) {
m.RLock()
value, ok := m.items[key]
m.RUnlock()
return value, ok
}
func (m *ConcurrentReadMap) Items() (itemsCopy []interface{}) {
m.RLock()
for _, i := range m.items {
itemsCopy = append(itemsCopy, i)
}
2016-06-03 02:06:05 +08:00
m.RUnlock()
2016-05-31 03:30:26 +08:00
return itemsCopy
}
func (m *ConcurrentReadMap) Delete(key string) {
m.Lock()
delete(m.items, key)
m.Unlock()
}