
协程输出缺失的探究
在学习 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 阻塞执行时会丢失输出?的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号