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 阻塞执行时会丢失输出?的详细内容,更多请关注其它相关文章!