登录
首页 >  Golang >  Go问答

危险信号:通道未缓冲,触发 goroutine 死锁

来源:stackoverflow

时间:2024-03-05 13:09:28 500浏览 收藏

学习知识要善于思考,思考,再思考!今天golang学习网小编就给大家带来《危险信号:通道未缓冲,触发 goroutine 死锁》,以下内容主要包含等知识点,如果你正在学习或准备学习Golang,就都不要错过本文啦~让我们一起来看看吧,能帮助到你就更好了!

问题内容

我尝试理解当通道未缓冲时出现的错误:

“致命错误:所有 goroutine 都在睡觉 - 死锁!”

package main

import "fmt"

func main() {
     ch := make(chan int)
     ch <- 1
     gg := <-ch 
     fmt.Println(gg)    
}

它在我缓冲通道 ch := make(chan int, 2) 后起作用


解决方案


通过非缓冲通道发送和检索数据都是阻塞进程。

在您的代码中,您尝试通过通道 ch 发送数值 1。由于该操作是阻塞的,因此在当前行执行完成之前,下面的代码不会被执行。

在执行语句 ch <- 1 期间,同时没有运行从通道 ch 检索数据的进程。由于通道类型是非缓冲通道,因此发送和检索过程需要完全相同的时间发生。

在下面的示例中,我创建了一个 goroutine,其中包含通过通道发送数据的代码,以及主例程中用于从通道检索数据的另一个代码。这是可行的,因为主例程和 goroutine 进程将分别并发执行。

go func () {
    ch <- 1
}()

gg := <-ch

工作演示:https://play.golang.org/p/ceIoVQLItNk

还有一种称为缓冲通道的东西。使用此功能,您将能够通过通道多次发送数据,即使尚未同时运行检索数据的进程。但有一个规则要遵循:只能发送 n 次,而 n 代表缓冲区编号。

示例1:发送数据2次(缓冲区设置为3),然后检索:

ch := make(chan int, 3)
ch <- 1
ch <- 1
gg := <-ch

示例2:发送数据4次(缓冲区设置为3),然后检索:

ch := make(chan int, 3)
ch <- 1
ch <- 1
ch <- 1
ch <- 1
gg := <-ch

更多信息:https://blog.golang.org/pipelines

终于介绍完啦!小伙伴们,这篇关于《危险信号:通道未缓冲,触发 goroutine 死锁》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布Golang相关知识,快来关注吧!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>