
协程输出缺失的探究
在学习 golang 并发编程时,初学者可能会遇到 goroutine 使用 channel 进行阻塞执行时出现输出缺失的情况。
示例代码如下:
package main
import (
"fmt"
"runtime"
"time"
)
func main() {
runtime.gomaxprocs(1)
c := make(chan bool)
for j := 0; j < 5; j++ {
go go(c, j)
}
<-c
}
func go(c chan bool, index int) {
a := 1
for i := 0; i < 100000000; i++ {
a += i
}
fmt.println(index, a)
if index == 4 {
c <- true
}
}预期输出:
立即学习“go语言免费学习笔记(深入)”;
0 5000000050000000 1 5000000050000000 2 5000000050000000 3 5000000050000000 4 5000000050000000
但是实际运行结果却可能是:
0 5000000050000000 4 5000000050000000
缺失了 1, 2, 3 输出,这可能是因为:
协程之间执行顺序不保证。调用 printf 会导致协程切换,所以当协程 4 打印完后,其他协程可能还没有来得及执行。当协程 4 再次执行并发送 true 信号时,getchannel 只会收到一次,导致其他协程输出缺失。










