Junior — Senior
49
Безопасный конкурентный доступ к глобальной карте
Компании, где спрашивали:
Lamoda Tech
Условие задачи
В программе объявлена глобальная карта map[string]int, к которой одновременно обращаются несколько горутин: одна читает, другая записывает. При таком параллелизме возникает паника fatal error: concurrent map read and map write. Требуется выбрать подходящий механизм синхронизации, чтобы избавиться от гонки и обеспечить корректную работу программы.
package main
import (
"fmt"
"sync"
"time"
)
var (
mu sync.RWMutex
m = map[string]int{"a": 1}
)
func main() {
go read()
time.Sleep(1 * time.Second)
go write()
time.Sleep(1 * time.Second)
}
func read() {
for {
mu.RLock()
fmt.Println(m["a"])
mu.RUnlock()
}
}
func write() {
for {
mu.Lock()
m["a"] = 2
mu.Unlock()
}
}
Каким способом синхронизации (например, мьютекс, RWMutex, sync.Map, каналы и т.д.) следует решить проблему?