Go 22 如何在併發場景中使用Map

2021-09-29 09:43:44 字數 983 閱讀 5074

go語言中的map在併發情況下,唯讀是執行緒安全的,同時讀寫是執行緒不安全的。

下面來看下併發情況下讀寫 map 時會出現的問題,**如下:

// 建立乙個int到int的對映

m := make(map[int]int)

// 開啟一段併發**

go func()

}()// 開啟一段併發**

go func()

}()// 無限迴圈, 讓併發程式在後台執行

for

執行**會報錯,輸出如下:

fatal error: concurrent map read and map write
錯誤資訊顯示,併發的 map 讀和 map 寫,也就是說使用了兩個併發函式不斷地對 map 進行讀和寫而發生了競態問題,map 內部會對這種併發操作進行檢查並提前發現。

需要併發讀寫時,一般的做法是加鎖,但這樣效能並不高,go語言在 1.9 版本中提供了一種效率較高的併發安全的 sync.map,sync.map 和 map 不同,不是以語言原生形態提供,而是在 sync 包下的特殊結構。

sync.map 有以下特性:

併發安全的 sync.map 演示**如下:

package main

import (

"fmt"

"sync"

)func main() ) bool )

}

**輸出如下:

100 true

iterate: egypt 200

iterate: greece 97

**說明如下:

sync.map 沒有提供獲取 map 數量的方法,替代方法是在獲取 sync.map 時遍歷自行計算數量,sync.map 為了保證併發安全有一些效能損失,因此在非併發情況下,使用 map 相比使用 sync.map 會有更好的效能。

如何在AndroidStudio中使用AIDL

本章節介紹如何在androidstudio中使用aidl 2.在aidl下建立乙個包,包裡建立乙個 aidl檔案,右鍵aidl new aidl aidl file 紅框就是建立完成後的樣子 3.在aidl檔案寫要被呼叫的方法,此方法不能有許可權修飾符 4.首先build下,然後建立乙個servic...

如何在Oracle中使用Sequence

sql server可以自增字段,但是oracle中在建表的時候可沒有這個選項,但是可以通過觸發器 trigger 或者序列 sequence 來實現,本文主要講述sequence。二者的區別oracle中自增字段的兩種方法的比較 trigger和sequence 建立sequence的語法很簡單,...

如何在Oracle中使用Sequence

sql server可以自增字段,但是oracle中在建表的時候可沒有這個選項,但是可以通過觸發器 trigger 或者序列 sequence 來實現,本文主要講述sequence。二者的區別oracle中自增字段的兩種方法的比較 trigger和sequence 在oracle中,沒有象ms sq...