golang中的race檢測

來源:互聯網
上載者:User
這是一個建立於 的文章,其中的資訊可能已經有所發展或是發生改變。

golang中的race檢測

由於golang中的go是非常方便的,加上函數又非常容易隱藏go。
所以很多時候,當我們寫出一個程式的時候,我們並不知道這個程式在並發情況下會不會出現什麼問題。

所以在本質上說,goroutine的使用增加了函數的危險係數論go語言中goroutine的使用。比如一個全域變數,如果沒有加上鎖,我們寫一個比較龐大的項目下來,就根本不知道這個變數是不是會引起多個goroutine競爭。

官網的文章Introducing the Go Race Detector給出的例子就說明了這點:

package mainimport(    "time"    "fmt"    "math/rand")func main() {    start := time.Now()    var t *time.Timer    t = time.AfterFunc(randomDuration(), func() {        fmt.Println(time.Now().Sub(start))        t.Reset(randomDuration())    })    time.Sleep(5 * time.Second)}func randomDuration() time.Duration {    return time.Duration(rand.Int63n(1e9))}

這個例子看起來沒任何問題,但是實際上,time.AfterFunc是會另外啟動一個goroutine來進行計時和執行func()。
由於func中有對t(Timer)進行操作(t.Reset),而主goroutine也有對t進行操作(t=time.After)。
這個時候,其實有可能會造成兩個goroutine對同一個變數進行競爭的情況。

這個例子可能有點複雜,我們簡化一下,使用一個更為簡單的例子:

package mainimport(    "time"    "fmt")func main() {    a := 1    go func(){        a = 2    }()    a = 3    fmt.Println("a is ", a)    time.Sleep(2 * time.Second)}

在上面的例子中,看代碼,我們其實看的出來,這裡的go func觸發的goroutine會修改a。
主goroutine 也會對a進行修改。但是我們如果只go run運行,我們可能往往不會發現什麼太大的問題。

runtime  go run race1.goa is  3

可喜的是,golang在1.1之後引入了競爭檢測的概念。我們可以使用go run -race 或者 go build -race 來進行競爭檢測。
golang語言內部大概的實現就是同時開啟多個goroutine執行同一個命令,並且紀錄每個變數的狀態。

如果用race來檢測上面的程式,我們就會看到輸出:

runtime  go run -race race1.goa is  3==================WARNING: DATA RACEWrite by goroutine 5:  main.func·001()      /Users/yejianfeng/Documents/workspace/go/src/runtime/race1.go:11 +0x3aPrevious write by main goroutine:  main.main()      /Users/yejianfeng/Documents/workspace/go/src/runtime/race1.go:13 +0xe7Goroutine 5 (running) created at:  main.main()      /Users/yejianfeng/Documents/workspace/go/src/runtime/race1.go:12 +0xd7==================Found 1 data race(s)exit status 66

這個命令輸出了Warning,告訴我們,goroutine5運行到第11行和main goroutine運行到13行的時候觸發競爭了。
而且goroutine5是在第12行的時候產生的。

這樣我們根據分析這個提示就可以看到這個程式在哪個地方寫的有問題了。

當然這個參數會引發CPU和記憶體的使用增加,所以基本是在測試環境使用,不是在正式環境開啟。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.