fatal error: all goroutines are asleep - deadlock!

go 复制代码
func main() {

	var taskChannle =make(chan int)

	taskChannle <- 1

	fmt.Println(<-taskChannle)

channel初始化时没有指定缓冲的话,默认是没有缓冲的。也就是说往channel中send数据是一个阻塞操作,直到Channle有读取操作。

所以当代码执行到taskChannle <- 1时就产生了阻塞,不会往下走,所以go就认为all goroutines are asleep - deadlock!

将代码改成如下:

go 复制代码
func main() {

	var taskChannle =make(chan int)

	go func() {
		fmt.Println(<-taskChannle)
	}()
	
	taskChannle <- 1

就不会产生死锁,或者声明带缓冲的channel

推荐阅读

1、原来阿里字节员工简历长这样

2、一条SQL差点引发离职

3、MySQL并发插入导致死锁


如果你也觉得我的分享有价值,记得点赞或者收藏哦!你的鼓励与支持,会让我更有动力写出更好的文章哦!

相关推荐
木雷坞3 小时前
Go 项目实战:用 MLiev IAM 落地企业认证中心
后端·golang·认证
吴佳浩11 小时前
Go史上最大“打脸”现场来了:泛型方法终于实现了
后端·go
知彼解己14 小时前
LLM-based Planning:从后端视角理解 Agent 规划层
后端·golang·ai编程
basketball61618 小时前
Go语言从入门到进阶:8. 接口
开发语言·后端·golang
明月_清风18 小时前
深入 Go 并发编程:从 Goroutine 到 Channel 的系统性避坑指南
后端·go
codeejun19 小时前
每日一Go-71、理论知识:CAP 、一致性原理 、Raft 机制(简化实现一个 Raft)
java·开发语言·golang
曾几何时`20 小时前
Go(一)Gin框架 和 GORM机制
开发语言·golang·gin
l齐天20 小时前
Ubuntu 22.04 环境下 PBC 与 Golang 的安装、配置与测试
linux·ubuntu·golang
codeejun20 小时前
每日一 Go-72、分布式事务 & 一致性:本地消息表、事务消息、SAGA、TCC怎么选?
开发语言·分布式·golang
用户34232323763171 天前
开源!Go+Wails+Vue3 手搓一个 PLC 实时监控桌面工具
go