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

Go 函数并发编程的最佳实践:何时使用 WaitGroup?
并发编程是 Go 语言的核心,它允许您编写可以充分利用多核 CPU 的高效程序。WaitGroup 是一个内置的并发原语,可帮助您执行以下操作:
何时使用 WaitGroup?
立即学习“go语言免费学习笔记(深入)”;
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 的优点包括:
以上就是Golang 函数并发编程的最佳实践:何时使用 WaitGroup?的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号