登录
首页 >  Golang >  Go问答

所有 golang goroutine 在等待 - 死锁

来源:stackoverflow

时间:2024-03-13 16:48:24 262浏览 收藏

在Golang实战开发的过程中,我们经常会遇到一些这样那样的问题,然后要卡好半天,等问题解决了才发现原来一些细节知识点还是没有掌握好。今天golang学习网就整理分享《所有 golang goroutine 在等待 - 死锁》,聊聊,希望可以帮助到正在努力赚钱的你。

问题内容

运行 follow golang 片段时出现错误。 我认为进度将在 wg.wait() 处阻塞,直到 go 例程结束。那么该值将从c1中获得。但它可能不会按预期进行。

func main() {

c1 := make(chan string)
//var c1 chan string
var wg sync.waitgroup

wg.add(1)
go func() {
    defer wg.done()
    fmt.printf("go routine begin\n")
    time.sleep(1 * time.second)
    c1 <- "one"
    fmt.printf("go routine done\n")
}()
wg.wait()
fmt.printf("done c1: %v\n", <-c1)
fmt.printf("out\n")
}

错误信息是,

go routine begin
 fatal error: all goroutines are asleep - deadlock!

解决方案


c1 的写入永远不会执行,因为从 c1 的读取是在 wg.Wait() 之后,它将停止,直到写入 c1 为止。所以主 goroutine 在 wg.Wait() 处等待,嵌套 goroutine 在 c1 write 处等待。

您可以使通道缓冲,或者等待 c1 在单独的 goroutine 上读取。

到这里,我们也就讲完了《所有 golang goroutine 在等待 - 死锁》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于的知识点!

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