登录
首页 >  Golang >  Go问答

goroutine 竞争条件解决方案

来源:stackoverflow

时间:2024-04-09 11:42:36 345浏览 收藏

知识点掌握了,还需要不断练习才能熟练运用。下面golang学习网给大家带来一个Golang开发实战,手把手教大家学习《goroutine 竞争条件解决方案》,在实现功能的过程中也带大家重新温习相关知识点,温故而知新,回头看看说不定又有不一样的感悟!

问题内容

我试图了解如何修复以下代码的竞争条件。

sayhello := func() {
    fmt.println("hello from goroutine")
}

go sayhello()
time.sleep(1)

fmt.println("hello, playground")

期望:我只是想知道最好的解决方案是什么,我应该使用waitgroup还是有更好的解决方案?

所以我想出了以下解决方案:

var wg sync.WaitGroup
//defer wg.Wait()
sayHello := func() {
    defer wg.Done()
    fmt.Println("Hello from goroutine")
}
wg.Add(1)

go sayHello()
wg.Wait()

fmt.Println("Hello, playground")

但是它会阻塞主 goroutine,直到代码执行为止!

同样,如果我使用 defer wg.wait() ,输出会有所不同! https://play.golang.org/p/_xklb7hvnf8

竞争条件我的意思是 go sayhello() 甚至永远不会被执行,因为 main func 将在 goroutine 启动之前完成执行。因此,如果我尝试设置时间,它会产生竞争条件。睡眠


解决方案


您的代码中没有 race condition

第一个问题

但是它会阻塞主 goroutine,直到代码执行为止!

您在 sayhello 调用之后立即使用:

wg.Wait()

这会阻塞你的代码并等待 goroutine 被执行。因此,go sayhello() 将始终在 "hello, 演示" 之前打印 "hello from goroutine"

请参阅文档 here

等待块,直到 waitgroup 计数器为零。

第二个问题

同样,如果我使用 defer wg.wait() ,输出会有所不同!

是的,在这种情况下,wg.wait()将在退出主函数之前执行。这意味着 sayhello() 将在 “hello, 演示” 之后打印 "hello from goroutine" - 这取决于 go 调度程序

查看有关 defer here 的更多信息

defer 语句将函数调用推送到列表中。保存的调用列表在周围函数返回后执行。 defer 通常用于简化执行各种清理操作的函数。

更新:

与使用通道的其他解决方案相比,建议使用 waitgroup。您应该在正确的位置使用 wg.wait() 来实现预期的输出(仍未提供)。

理论要掌握,实操不能落!以上关于《goroutine 竞争条件解决方案》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

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