sync: implement sync.Map
This is a very simple implementation, just enough to get packages to compile.
Этот коммит содержится в:
родитель
f8876ea245
коммит
67c242173c
1 изменённых файлов: 44 добавлений и 0 удалений
44
src/sync/map.go
Обычный файл
44
src/sync/map.go
Обычный файл
|
@ -0,0 +1,44 @@
|
||||||
|
package sync
|
||||||
|
|
||||||
|
// This file implements just enough of sync.Map to get packages to compile. It
|
||||||
|
// is no more efficient than a map with a lock.
|
||||||
|
|
||||||
|
type Map struct {
|
||||||
|
lock Mutex
|
||||||
|
m map[interface{}]interface{}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *Map) Delete(key interface{}) {
|
||||||
|
m.lock.Lock()
|
||||||
|
defer m.lock.Unlock()
|
||||||
|
delete(m.m, key)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *Map) Load(key interface{}) (value interface{}, ok bool) {
|
||||||
|
m.lock.Lock()
|
||||||
|
defer m.lock.Unlock()
|
||||||
|
value, ok = m.m[key]
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *Map) LoadOrStore(key, value interface{}) (actual interface{}, loaded bool) {
|
||||||
|
m.lock.Lock()
|
||||||
|
defer m.lock.Unlock()
|
||||||
|
if m.m == nil {
|
||||||
|
m.m = make(map[interface{}]interface{})
|
||||||
|
}
|
||||||
|
if existing, ok := m.m[key]; ok {
|
||||||
|
return existing, true
|
||||||
|
}
|
||||||
|
m.m[key] = value
|
||||||
|
return value, false
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *Map) Store(key, value interface{}) {
|
||||||
|
m.lock.Lock()
|
||||||
|
defer m.lock.Unlock()
|
||||||
|
if m.m == nil {
|
||||||
|
m.m = make(map[interface{}]interface{})
|
||||||
|
}
|
||||||
|
m.m[key] = value
|
||||||
|
}
|
Загрузка…
Создание таблицы
Сослаться в новой задаче