Go使用sync.Map來解決map的并發(fā)操作問題
前言
在 Golang 中 map 不是并發(fā)安全的,自 1.9 才引入了 sync.Map ,sync.Map 的引入確實解決了 map 的并發(fā)安全問題,不過 sync.Map 卻沒有實現(xiàn) len() 函數(shù),如果想要計算 sync.Map 的長度,稍微有點麻煩,需要使用 Range 函數(shù)。
map 并發(fā)操作出現(xiàn)問題
func main() {
demo := make(map[int]int)
go func() {
for j := 0; j < 1000; j++ {
demo[j] = j
}
}()
go func() {
for j := 0; j < 1000; j++ {
fmt.Println(demo[j])
}
}()
time.Sleep(time.Second * 1)
}
執(zhí)行輸出:
fatal error: concurrent map read and map write
sync.Map 解決并發(fā)操作問題
func main() {
demo := sync.Map{}
go func() {
for j := 0; j < 1000; j++ {
demo.Store(j, j)
}
}()
go func() {
for j := 0; j < 1000; j++ {
fmt.Println(demo.Load(j))
}
}()
time.Sleep(time.Second * 1)
}
執(zhí)行輸出:
<nil> false
1 true...
999 true
計算 map 長度
func main() {
demo := make(map[int]int)
for j := 0; j < 1000; j++ {
demo[j] = j
}
fmt.Println("len of demo:", len(demo))
}
執(zhí)行輸出:
len of demo: 1000
計算 sync.Map 長度
func main() {
demo := sync.Map{}
for j := 0; j < 1000; j++ {
demo.Store(j, j)
}
lens := 0
demo.Range(func(key, value interface{}) bool {
lens++
return true
})
fmt.Println("len of demo:", lens)
}
執(zhí)行輸出:
len of demo: 1000
小結(jié)
- Load 加載 key 數(shù)據(jù)
- Store 更新或新增 key 數(shù)據(jù)
- Delete 刪除 key 數(shù)據(jù)
- Range 遍歷數(shù)據(jù)
- LoadOrStore 如果存在 key 數(shù)據(jù)則返回,反之則設置
- LoadAndDelete 如果存在 key 數(shù)據(jù)則刪除
到此這篇關于Go使用sync.Map來解決map的并發(fā)操作問題的文章就介紹到這了,更多相關Go sync.Map解決map并發(fā)操作內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Go基本數(shù)據(jù)類型與string類型互轉(zhuǎn)
本文主要介紹了Go基本數(shù)據(jù)類型與string類型互轉(zhuǎn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-03-03

