为什么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
    }
}

实际输出结果

goroutine使用channel阻塞执行时存在缺失的情况

通过多方谷歌和百多搜索没有找到原因,望各位帮忙解答一下

阅读 2.5k
2 个回答

协和应该不保证执行顺序吧. Println这个函数是输出函数, 应该会引起协和切换.
你的管道只输出了最后一个4, 另外几个0,1,2,3有可能4都执行完了, 还没执行完.

你的进程随着main函数的结束退出了, 协程自然也退出了.
简单点的做法是在main的最后sleep1秒钟即可.

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
宣传栏