golang报错: all goroutines are asleep - deadlock!

在测试go channel时出现如下错误提示:fatal error: all goroutines are asleep - deadlock!

出错信息的意思是在main goroutine线中,期待从其他goroutine线放入数据,但是其他goroutine线都已经执行完了(all goroutines are asleep),那么就永远不会有数据放入管道。 所以,main goroutine线在等一个永远不会来的数据,那整个程序就永远等下去了。 这个时候就会报上述错误。验证:

package main

import (
    "fmt"
)

func main() {
    ch1 := make (chan int)
    for {
        select {
        case  <-ch1:
            {
                fmt.Println("ch1 pop one")

            }
        }
    }

}
运行提示错误:
fatal error: all goroutines are asleep - deadlock!

在上面代码中加一个goroutine并sleep,代码会等待该gorutine结束后再打印该错误

package main

import (
    "fmt"
    "time"
)

func main() {
    ch1 := make (chan int)
    go func() {
        fmt.Println("sleep 1")
        time.Sleep(5 * time.Second)
        fmt.Println("sleep 2")
    }()

    for {
        select {
        case  <-ch1:
            {
                fmt.Println("ch1 pop one")

            }
        }
    }

}
打印结果:
sleep 1
sleep 2
fatal error: all goroutines are asleep - deadlock!

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏CRM日记本

马克.贝尼奥夫表示数据科学的变革会彻底改变我们商业运作的方式

Salesforce CEO 马克贝尼奥夫因为他的前瞻性而著称。今天在接受福布斯的采访时,他阐述了他对未来技术与商业发展的预测。

8520
来自专栏Pulsar-V

Python内核源码解析与C/CPP-API拓展编程(二)类型对象

在上一篇中我们了解到了 PyObject 这个结构只有两个内容:一个引用计数, 一个类型信息. 但是在现实的编程过程中缺失了一些去区别python每一个类型的信...

10400
来自专栏帅哥哥写代码

sql功底展示

14120
来自专栏让技术和时代并行

适配器模式

适配器模式的定义:将一个类的接口变成另一个客户端所期待的的接口,从而使原本因接口不匹配而无法在一起工作的两个类都能在一起工作。

8030
来自专栏FREE SOLO

同步与异步、阻塞与非阻塞

简单来说,同步是一种可靠的有序运行机制,当我们进行同步操作时,后续的任务是等待当前调用返回,才会进行下一步;而异步则相反,其他任务不需要等待当前调用返回,通常依...

12900
来自专栏CRM日记本

Salesforce CPQ:让客户更满意,让销售更高效

你和你的销售团队希望更快的赢得交易,这是你使用Salesforce的一个原因。这也是一个很好的理由花时间学习CPQ的原因,在这里你会了解Salesforce C...

10730
来自专栏无所事事者爱嘲笑

npm、cnpm、yarn 安装删除异同

一直觉得npm、cnpm、yarn的安装删除基本一样用哪个都行,不过俗话说的好,实践出真知,这里记录一下今天简单测试得到的结果总结。

1.3K10
来自专栏极乐技术社区

小程序 · 一周报

目前,通过绑定至同一个公众号,两个小程序就能便捷地互相访问,方便用户使用更多服务。

13720
来自专栏极乐技术社区

小程序 · 一周报

3. 在线客服展示:支持用户查找门店服务时快速打开客服对话窗口,向在线客服人员进行咨询。

10330
来自专栏FREE SOLO

synchronized和ReentrantLock有什么区别呢?

1.原子性,简单说就是相关操作不会中途被其他线程干扰,一般通过同步机制实现。 2.可见性,是一个线程修改了某个共享变量,其状态能够立即被其他线程知晓,通常被解...

44900

扫码关注云+社区

领取腾讯云代金券

年度创作总结 领取年终奖励