转自个人博客 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()
}

在不执行代码的前提下,脑补一下输出结果应该是什么。

我再看到这道题时,首先想到输出应该是0 -- 9 依次输出。 但执行后才大跌眼镜,错的不是一点半点。首先看一下,在我本地执行的结果:

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

意不意外? 惊不惊喜?

为什么会是这样的结果, 再翻阅了google官方出品的golang文档之后,总算搞到了一些头绪。

并发不等于并行

golang的核心开发人员Rob Pike专门提到了这个话题(有兴趣可以看这个视频或者看原文PPT)

延伸阅读

学习是年轻人改变自己的最好方式-Java培训,做最负责任的教育,学习改变命运,软件学习,再就业,大学生如何就业,帮大学生找到好工作,lphotoshop培训,电脑培训,电脑维修培训,移动软件开发培训,网站设计培训,网站建设培训学习是年轻人改变自己的最好方式