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并发插入导致死锁


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

相关推荐
宁瑶琴11 小时前
COBOL语言的云计算
开发语言·后端·golang
m0_6948455718 小时前
UVdesk部署教程:企业级帮助台系统实践
服务器·开发语言·后端·golang·github
@atweiwei18 小时前
Go语言面试篇数据结构底层原理精讲(下)
数据结构·面试·golang
XMYX-019 小时前
03 - Go 常用类型速查表 + 实战建议(实战向)
开发语言·golang
@atweiwei21 小时前
Go语言面试篇数据结构底层原理精讲(上)
数据结构·面试·golang
呆萌很21 小时前
【GO】结构体方法练习题
golang
女王大人万岁1 天前
Golang实战gRPC与Protobuf:从入门到进阶
服务器·开发语言·后端·qt·golang
人间打气筒(Ada)1 天前
「码动四季·开源同行」go语言:如何使用 ELK 进行日志采集以及统一处理?
开发语言·分布式·elk·go·日志收集·分布式日志系统
Generalzy1 天前
Go 浏览器自动化大比拼:chromedp vs rod
开发语言·golang·自动化
LlNingyu1 天前
什么是Go的接口(一)
开发语言·后端·golang