首页 > 后端开发 > Golang > 正文

如何使用sync.WaitGroup来执行所有的goroutine?

PHPz
发布: 2024-02-09 11:40:09
转载
751 人浏览过

如何使用sync.WaitGroup来执行所有的goroutine?

php小编苹果为您介绍一种实用的方法来执行所有的goroutine - sync.WaitGroup。在Go语言中,goroutine是轻量级的线程,可以同时执行多个任务。然而,有时我们需要等待所有的goroutine执行完毕后再继续下一步操作。这时,sync.WaitGroup就派上用场了。它提供了一种简单而有效的方式来等待所有的goroutine完成,确保程序的正确执行顺序。接下来,我们将详细介绍如何使用sync.WaitGroup来实现这个功能。

问题内容

目前我正在将所有值推送到通道并从中读取并计算其平方。 我想避免使用 time.sleep(2000 * time.millisecond) 因为它会阻止执行 2 秒,而是我希望每个 goroutine 都处理并等待其执行,然后退出程序。我刚刚脱离了 golang,所以现在问这个基本问题:(。有人能帮我解决这个问题吗?

package main

import (
    "fmt"
    "sync"
    "time"
)

func doSquare(num int) int {
    return num * num
}

var wg sync.WaitGroup

func main() {

    wg.Add(1)
    st := []int{1, 2, 3, 4, 5, 6, 7, 8, 9, 10}
    quit := make(chan bool)
    ch := make(chan int)
    go func() {
        for i := range st {
            ch <- i
        }
    }()

    go func() {
        for {
            select {
            case x := <-ch:
                fmt.Println(doSquare(x))
                // return

            case <-quit:
                wg.Done()
            default:
                // fmt.Println("---")
                // do something
            }
        }
    }()

    quit <- true

    wg.Wait()
    time.Sleep(2000 * time.Millisecond)
}
登录后复制

解决方法

只需将 qui​​t <- true 移至第一个 goroutine 的末尾即可

func main() {
    wg.add(1)
    st := []int{1, 2, 3, 4, 5, 6, 7, 8, 9, 10}
    quit := make(chan bool)
    ch := make(chan int)
    go func() {
        for i := range st {
            ch <- i
        }
        quit <- true
    }()

    go func() {
        for {
            select {
            case x := <-ch:
                fmt.println(dosquare(x))
                // return

            case <-quit:
                wg.done()
                return
            default:
                // fmt.println("---")
                // do something
            }
        }
    }()

    wg.wait()
}
登录后复制

这是 close(ch) 表示没有更多数据的另一种方式

func main() {
    st := []int{1, 2, 3, 4, 5, 6, 7, 8, 9, 10}
    quit := make(chan bool)
    ch := make(chan int) // improve concurrency by `ch := make(chan int, 100)`
    go func() {
        for i := range st {
            ch <- i
        }
        close(ch)
    }()

    go func() {
        for x := range ch {
            fmt.Println(doSquare(x))
        }
        quit <- true
    }()

    <-quit
}
登录后复制

以上是如何使用sync.WaitGroup来执行所有的goroutine?的详细内容。更多信息请关注PHP中文网其他相关文章!

相关标签:
来源:stackoverflow.com
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!