由於golang中的go是非常方便的,加上函式又非常容易隱藏go。
所以很多時候,當我們寫出乙個程式的時候,我們並不知道這個程式在併發情況下會不會出現什麼問題。
所以在本質上說,goroutine的使用增加了函式的危險係數論go語言中goroutine的使用。比如乙個全域性變數,如果沒有加上鎖,我們寫乙個比較龐大的專案下來,就根本不知道這個變數是不是會引起多個goroutine競爭。
官網的文章introducing the go race detector給出的例子就說明了這點:
package main
import(
"time"
"fmt"
"math/rand"
)func main() )
time.sleep(5 * time.second)
}func randomduration() time.duration
這個例子看起來沒任何問題,但是實際上,time.afterfunc是會另外啟動乙個goroutine來進行計時和執行func()。
由於func中有對t(timer)進行操作(t.reset),而主goroutine也有對t進行操作(t=time.after)。
這個時候,其實有可能會造成兩個goroutine對同乙個變數進行競爭的情況。
這個例子可能有點複雜,我們簡化一下,使用乙個更為簡單的例子:
package main
import(
"time"
"fmt"
)func main() ()
a = 3
fmt.println("a is ", a)
time.sleep(2 * time.second)
}
在上面的例子中,看**,我們其實看的出來,這裡的go func觸發的goroutine會修改a。
主goroutine 也會對a進行修改。但是我們如果只go run執行,我們可能往往不會發現什麼太大的問題。
runtime go run race1.go
a is 3
可喜的是,golang在1.1之後引入了競爭檢測的概念。我們可以使用go run -race 或者 go build -race 來進行競爭檢測。
golang語言內部大概的實現就是同時開啟多個goroutine執行同乙個命令,並且紀錄每個變數的狀態。
如果用race來檢測上面的程式,我們就會看到輸出:
runtime go run -race race1.go
a is 3
***************===
warning: data race
write by goroutine 5:
main.func·001()
/users/yejianfeng/documents/workspace/go/src/runtime/race1.go:11 +0x3a
previous write by main goroutine:
main.main()
/users/yejianfeng/documents/workspace/go/src/runtime/race1.go:13 +0xe7
goroutine 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和記憶體的使用增加,所以基本是在測試環境使用,不是在正式環境開啟。
promise中all和race的區別
1 promise.all a,b 會將a,b的引數都一起返回 所用時間為a b 2 promise.race a,b 會將定時器時間執行時間短的引數返回 把以下 放在除錯工具,看列印結果的先後順序,以及列印時間就能明白了 const moviepromise new promise reslove...
golang埠占用檢測
在運維開發的過程中,經常碰到這樣的情況 啟動某個應用前,需要先檢測一下埠是否被其他的應用占用了,若占用了,能否得到占用程序的pid。後續可以根據這個pid,查詢是哪個應用佔據這埠,然後kill掉。非常簡單的需求,思路是 利用 netstat 命令獲取當前的相關埠號的pid,然後正規表示式過濾出相關的...
promise中的all方法和race方法
這兩個方法,都是並行執行多個非同步操作。而不同的是,all方式遵循 誰跑得慢,以誰為準執行 而race遵循的是 誰跑的快,以誰為準執行 以下為兩個非同步函式 function yibu1 3000 return p1 function yibu2 2000 return p2 當使用all實現並行執...