登录
首页 >  Golang >  Go问答

errgroup 的竞争条件是什么?

来源:stackoverflow

时间:2024-02-15 18:21:28 300浏览 收藏

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

问题内容

g.Go(func() error {
    result, err := makeDBCall()
    if err != nil {
        fmt.Println("Error 1")
        return err
    }
    return nil
}

g.Go(func() error {
    result, err := makeAnotherDBCall()
    if err != nil {
        fmt.Println("Error 2")
        return err
    }
    return nil
}

g.Go(func() error {
    result, err := makeAnotherAnotherDBCall()
    if err != nil {
        fmt.Println("Error 3")
        return err
    }
    return nil
}

err := g.Wait()
if err != nil {
    return
}

fmt.Println("Done with error Group")

我故意使 dbcall() 函数之一返回错误。在发出的 10 个请求中,可能有 3-5 个的输出为:

启动错误组

错误1

已完成错误组


解决方案


docs for errgroup 表示“第一个返回非零错误的调用会取消该组;其错误将由 Wait 返回。”

由于这些是同时运行的,因此无法预测故障发生的顺序。有时它会立即发生,有时仅在其他 goroutine 成功运行后发生。平均而言,在出现错误之前,听起来好像有 3-5 个正在运行。一旦发生该错误,该组就会被取消,并且任何尚未启动的 goroutine 将根本不会运行。

今天关于《errgroup 的竞争条件是什么?》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!

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