func main() {
var taskChannle =make(chan int)
taskChannle <- 1
fmt.Println(<-taskChannle)
channel初始化时没有指定缓冲的话,默认是没有缓冲的。也就是说往channel中send数据是一个阻塞操作,直到Channle有读取操作。
所以当代码执行到taskChannle <- 1时就产生了阻塞,不会往下走,所以go就认为all goroutines are asleep - deadlock!
将代码改成如下:
func main() {
var taskChannle =make(chan int)
go func() {
fmt.Println(<-taskChannle)
}()
taskChannle <- 1
就不会产生死锁,或者声明带缓冲的channel
推荐阅读
如果你也觉得我的分享有价值,记得点赞或者收藏哦!你的鼓励与支持,会让我更有动力写出更好的文章哦!
文章讲述了Go语言中channel的阻塞行为以及如何通过使用缓冲channel来防止死锁。作者通过示例说明了未指定缓冲的channel在并发中的影响,并推荐了解决并发问题的最佳实践,如使用缓冲channel和理解数据库并发插入可能导致的死锁。
2086

被折叠的 条评论
为什么被折叠?



