Golang 协程输出缺失:为什么 goroutine 使用 channel 阻塞执行时会丢失输出?

golang 协程输出缺失:为什么 goroutine 使用 channel 阻塞执行时会丢失输出?

协程输出缺失的探究

在学习 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 只会收到一次,导致其他协程输出缺失。

以上就是Golang 协程输出缺失:为什么 goroutine 使用 channel 阻塞执行时会丢失输出?的详细内容,更多请关注其它相关文章!