golang协程执行顺序的问题
最近面试遇到一个代码问题
package main
import (
"fmt"
"runtime"
"sync"
)
func main() {
runtime.GOMAXPROCS(1)
wg := sync.WaitGroup{}
wg.Add(10)
for i := 0; i < 5; i++ {
go func() {
fmt.Println("A:", i)
wg.Done()
}()
}
for i := 0; i < 5; i++ {
go func(num int) {
fmt.Println("B:", num)
wg.Done()
}(i)
}
wg.Wait()
}
问上面代码输出结果是啥?
我当时回答是
A: 5
A: 5
A: 5
A: 5
A: 5
B: 0
B: 1
B: 2
B: 3
B: 4
但是我跑代码后结果却是:
B: 4
A: 5
A: 5
A: 5
A: 5
A: 5
B: 0
B: 1
B: 2
B: 3
请教B: 4
为啥会第一个打印,go的携程是如何调度的呢?我一开始还以为是用队列(先进先出的规则)来调度的呢,但并不是。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
本来以为是老套的 GMP 面试题,没啥意思,但仔细看了下感觉又不对。于是在爆栈搜了一圈之后找到个类似的问题,是问为什么连续启动多个goroutine总是先运行最后一个,例程和你的例子很像。
stackoverflow/goroutines-always-execute-last-in-first-out
能得到的一个首要的结论是:不要依赖于 goroutine 的调度顺序,在语言上这是未定义的(go 1.5 release note)。
就跟写 C/C++ 的时候依赖于某个编译器在某个平台上对某个未定义行为的行为一样,是非常不好的埋地雷行为,即使凑巧运行起来了,也应该直接视作 BUG。
遗憾的是依然没找到表现出这一行为的具体原因,只能确定这事儿不归我们这些只是 用 Go 写代码的搬砖工管。