协程输出缺失的探究
在学习 golang 并发编程时,初学者可能会遇到 goroutine 使用 channel 进行阻塞执行时出现输出缺失的情况。
示例代码如下:
package mainimport ( "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 50000000500000001 50000000500000002 50000000500000003 50000000500000004 5000000050000000
登录后复制
但是实际运行结果却可能是:
0 50000000500000004 5000000050000000
登录后复制
缺失了 1, 2, 3 输出,这可能是因为:
协程之间执行顺序不保证。调用 printf 会导致协程切换,所以当协程 4 打印完后,其他协程可能还没有来得及执行。当协程 4 再次执行并发送 true 信号时,getchannel 只会收到一次,导致其他协程输出缺失。
以上就是Golang 协程输出缺失:为什么 goroutine 使用 channel 阻塞执行时会丢失输出?的详细内容,更多请关注【创想鸟】其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。
发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2314855.html