清華尹成帶你實戰GO案例(62)Go 原子計數器

尹成發表於2018-05-22
Go 原子計數器
Go裡面的管理協程狀態的主要機制就是通道通訊。這些我們上面的例子介紹過。這裡還有一些管理狀態的

機制,下面我們看看多協程原子訪問計數器的例子,這個功能是由sync/atomic包提供的函式來實現的。
package main
import "fmt"
import "time"
import "sync/atomic"
import "runtime"
func main() {
// 我們使用一個無符號整型來代表一個永遠為正整數的counter
var ops uint64 = 0
// 為了模擬並行更新,我們使用50個協程來每隔1毫秒來
// 增加一下counter值,注意這裡的50協程裡面的for迴圈,
// 也就是說如果主協程不退出,這些協程將永遠執行下去
// 所以這個程式每次輸出的值有可能不一樣
for i := 0; i < 50; i++ {
go func() {
for {
// 為了能夠保證counter值增加的原子性,我們使用
// atomic包中的AddUint64方法,將counter的地址和
// 需要增加的值傳遞給函式即可
atomic.AddUint64(&ops, 1)
// 允許其他的協程來處理
runtime.Gosched()
}
}()
}
//等待1秒中,讓協程有時間執行一段時間
time.Sleep(time.Second)
// 為了能夠在counter仍被其他協程更新值的同時安全訪問counter值,
// 我們獲取一個當前counter值的拷貝,這裡就是opsFinal,需要把
// ops的地址傳遞給函式`LoadUint64`
opsFinal := atomic.LoadUint64(&ops)
fmt.Println("ops:", opsFinal)
}


我們多執行幾次,結果如下:
ops: 7499289
ops: 7700843

ops: 7342417





網址:http://www.qukuailianxueyuan.io/



欲領取造幣技術與全套虛擬機器資料

區塊鏈技術交流QQ群:756146052  備註:CSDN

尹成學院微信:備註:CSDN



網址:http://www.qukuailianxueyuan.io/



欲領取造幣技術與全套虛擬機器資料

區塊鏈技術交流QQ群:756146052  備註:CSDN

尹成學院微信:備註:CSDN

相關文章