轉(zhuǎn)自個人博客 chinazt.cc

先看下面一道面試題:

func main() {
runtime.GOMAXPROCS(1)
wg := sync.WaitGroup{}
wg.Add(20)for i := 0; i < 10; i++ {
go func() {
fmt.Println("go routine 1 i: ", i)
wg.Done()
}()
}for i := 0; i < 10; i++ {
go func(i int) {
fmt.Println("go routine 2 i: ", i)
wg.Done()
}(i)

}
wg.Wait()
}

在不執(zhí)行代碼的前提下,腦補一下輸出結(jié)果應該是什么。

我再看到這道題時,首先想到輸出應該是0 -- 9 依次輸出。 但執(zhí)行后才大跌眼鏡,錯的不是一點半點。首先看一下,在我本地執(zhí)行的結(jié)果:

go routine 2 i: 9go routine 1 i: 10go routine 1 i: 10go routine 1 i: 10go routine 1 i: 10go routine 1 i: 10go routine 1 i: 10go routine 1 i: 10go routine 1 i: 10go routine 1 i: 10go routine 1 i: 10go routine 2 i: 0go routine 2 i: 1go routine 2 i: 2go routine 2 i: 3go routine 2 i: 4go routine 2 i: 5go routine 2 i: 6go routine 2 i: 7go routine 2 i: 8

意不意外? 驚不驚喜?

為什么會是這樣的結(jié)果, 再翻閱了google官方出品的golang文檔之后,總算搞到了一些頭緒。

并發(fā)不等于并行

golang的核心開發(fā)人員Rob Pike專門提到了這個話題(有興趣可以看這個視頻或者看原文PPT)

網(wǎng)友評論