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


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

相关推荐
刀法如飞9 小时前
Go数组去重的20种实现方式,AI时代解决问题的不同思路
后端·算法·go
会编程的土豆13 小时前
由c/c++速通go语言,新手必看
c语言·c++·golang
念何架构之路17 小时前
Go Socket编程
开发语言·后端·golang
AI编程探险者19 小时前
Go 编译的二进制突然跑不起来了?凶手是 macOS 的 syspolicyd
go
codeejun19 小时前
每日一Go-59、云原生入门为什么一定要学Docker?
docker·云原生·golang
初心未改HD20 小时前
gRPC 与 Protobuf 实战指南
开发语言·golang
jieyucx21 小时前
Go语言切片:动态灵活的数据序列
算法·golang·指针·顺序表·数组·结构体·切片
用户3983461612021 小时前
10 个示例快速入门 Go-Spring|v1.3.0 正式发布
go
初心未改HD1 天前
Go 文件与 I/O 操作完全指南
开发语言·golang
geovindu1 天前
go: Mediator Pattern
设计模式·golang·中介者模式