goroutine使用channel阻塞执行时存在输出缺失的情况
Go初学者,在学习 @无闻 大神的 《Go编程基础(视频)》 的第14课并发时,对其中的示例代码有疑问,本地执行的输出结果不符合预期。
运行环境
$ go version
go version go1.17.2 darwin/arm64
问题描述
预期应该是阻塞执行,按顺序0-4输出全部结果,实际多次执行输出时中间会存在缺失的情况
func main() {
num1 := runtime.GOMAXPROCS(1)
num2 := runtime.GOMAXPROCS(1)
fmt.Println("num1:", num1, "num2:", num2)
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
}
}
实际输出结果
通过多方谷歌和百多搜索没有找到原因,望大家能帮忙解答一下
根据给出的代码片段,如果第一次执行的是 index=4 的 goroutine,main 这个主 goroutine 则会执行完毕,剩下的子 goroutine 则会被丢弃,所以这一步需要让主 goroutine 阻塞,可以使用 sync.WaitGroup。
如果没有加同步控制,goroutine的执行顺序是无法预测。想要实现顺序输出的话,可以使用 sync/atomic 进行原子操作,每执行到指定的 index 时原子递增,否则等待。
案例:
案例输出: