【Go】关于goroutine阻塞引发panic
ch := make(chan int, 10)
for i := 0; i <= 10; i++ {
ch <- i
}
go func() {
for v := range ch {
fmt.Println(v)
}
}()
这是一道面试题,问这段代码运行结果。
这段代码大体可以分为两部分,主协程创建一个缓冲区大小为10的int类型的channel并且循环写入0-10共11个元素,子协程消费channel并打印。
对channel熟悉的人可能会发现,缓冲区大小小于写入元素个数,写完9后channel会阻塞主,10无法再写入。再往下执行可能就不确定了,感觉goroutine会打印0-9。恭喜你,已经踩到坑了。
这段代码的坑就在于goroutine执行在后面,当主协程向channel写满10个后就已经阻塞程序执行了,也就不会走到goroutine消费这一步骤,最终导致程序卡死,报出fatal错误:fatal error: all goroutines are asleep - deadlock!