Golang 函数并发编程的最佳实践:何时使用 WaitGroup?

最佳实践:使用 waitgroup 管理 goroutine 并发何时使用 waitgroup:用于等待所有子例程完成后再继续执行。使用方法:wg.add(n):添加 goroutine 数量。wg.wait():阻塞调用程序,直到所有 goroutine 完成。wg.done():goroutine 完成时递减计数。优点:简单、可扩展、安全,防止数据争用。

Golang 函数并发编程的最佳实践:何时使用 WaitGroup?

Go 函数并发编程的最佳实践:何时使用 WaitGroup?

并发编程是 Go 语言的核心,它允许您编写可以充分利用多核 CPU 的高效程序。WaitGroup 是一个内置的并发原语,可帮助您执行以下操作:

  • 等待一组 goroutine 完成任务
  • 跟踪 goroutine 的数量
  • 在所有 goroutine 完成之前阻止调用程序

何时使用 WaitGroup?

WaitGroup 适用于需要等到所有子例程完成任务后才能继续执行的场景。典型的用例包括:

  • 从多个来源收集数据
  • 执行一系列异步任务
  • 处理请求管道

实战案例

考虑这样一个场景:您有一个 HTTP 服务,该服务使用 goroutine 从多个 API 获取数据。您希望在所有数据收集完成之前阻止 HTTP 响应,以便您可以将完整的响应发送给客户端。

代码示例

使用WaitGroup实现此操作:

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

func main() {
    var wg sync.WaitGroup

    // 创建一个管道以接收每个 goroutine 的结果
    resultChan := make(chan string)

    // 创建 3 个 goroutine 从不同的 API 获取数据
    wg.Add(3)
    for i := 0; i < 3; i++ {
        go func(i int) {
            defer wg.Done() // 递减 WaitGroup 计数

            // 模拟 API 调用
            time.Sleep(time.Second)
            resultChan <- fmt.Sprintf("结果 %d", i)
        }(i)
    }

    // 等待所有 goroutine 完成
    wg.Wait()

    // 从管道中收集结果
    var results []string
    for {
        select {
        case result, ok := <-resultChan:
            if !ok {
                break
            }
            results = append(results, result)
        }
    }

    // 将完整响应发送给客户端
    fmt.Println(results)
}

使用方法

  • wg.Add(n):将 goroutine 的数量添加到 WaitGroup。
  • wg.Wait():阻塞调用程序,直到 WaitGroup 的计数变为 0。
  • wg.Done():当 goroutine 完成其任务时,它应该调用此方法以递减 WaitGroup 计数。

优点

使用 WaitGroup 的优点包括:

  • 简单性:它提供了一种简单且有效的方式来同步 goroutine。
  • 可扩展性:它可以很容易地扩展到支持大量并发任务。
  • 安全性:它防止在所有 goroutine 完成任务之前继续执行,有助于避免数据争用。

以上就是Golang 函数并发编程的最佳实践:何时使用 WaitGroup?的详细内容,更多请关注其它相关文章!