golang 死锁 all goroutines are asleep - deadlock!
channel死锁
package main import "fmt" func main() { ch := make(chan string) for i := 0; i < 10; i++ { s := <- ch fmt.Println(s) } go func(ch chan string) { for i := 0; i < 10; i++ { ch <- fmt.Sprintf("%d", i) } }(ch) }
报错
all goroutines are asleep - deadlock!
分析:无缓冲通道,只有接收端和发送端都准备好才会通过channel传输数据,所以main方法执行到
s := <- ch
这行代码会一直阻塞等待接收端准备好才能往下运行,而阻塞后接受端的代码就会一直运行不到,就会产生死锁。
解决
思路:先开启一个协程让运行接收端/发送端,main主协程继续往下执行。两个协程(接收断/发送端)都准备好后,就开始传输数据。
package main import "fmt" func main() { ch := make(chan string) go func(ch chan string) { for i := 0; i < 10; i++ { ch <- fmt.Sprintf("%d", i) } }(ch) for i := 0; i < 10; i++ { s := <- ch fmt.Println(s) }
声明 欢迎转载,但请保留文章原始出处:) 博客园:https://www.cnblogs.com/chenxiaomeng/
如出现转载未声明 将追究法律责任~谢谢合作
分类:
Golang
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具