WaitGroup用于等待多个协程完成,通过Add增加计数、Done减少计数、Wait阻塞直至计数为零,主协程可据此同步子协程执行。

在Go语言中,WaitGroup 是 sync 包提供的一个同步原语,用于等待一组并发的协程(goroutine)执行完成。它特别适用于主协程需要等待多个子协程结束的场景,比如批量任务处理、并行请求等。
WaitGroup 内部维护一个计数器,通过三个方法来控制:
典型使用模式是:主协程调用 Add 设置任务数量,每个子协程执行完任务后调用 Done,主协程通过 Wait 阻塞等待所有任务完成。
下面是一个简单的例子,展示如何用 WaitGroup 管理5个并发协程:
立即学习“go语言免费学习笔记(深入)”;
package main
import (
"fmt"
"sync"
"time"
)
func worker(id int, wg *sync.WaitGroup) {
defer wg.Done() // 任务完成,计数器减一
fmt.Printf("Worker %d starting\n", id)
time.Sleep(time.Second) // 模拟工作
fmt.Printf("Worker %d done\n", id)
}
func main() {
var wg sync.WaitGroup
for i := 1; i <= 5; i++ {
wg.Add(1) // 增加等待计数
go worker(i, &wg) // 启动协程
}
wg.Wait() // 等待所有协程完成
fmt.Println("All workers finished")
}
在这个例子中,main 函数启动5个 worker 协程,每个都传入同一个 WaitGroup 指针。使用 defer wg.Done() 确保即使发生 panic 也能正确通知完成。
虽然 WaitGroup 简单易用,但有几个关键点需要注意:
常见错误是把 Add 放在 goroutine 内部调用,这可能导致主协程还没来得及增加计数就进入 Wait,造成逻辑错乱。
WaitGroup 适合已知任务数量且只需等待完成的场景。如果任务数量动态变化或需要传递结果,可以结合 channel 使用。对于更复杂的协调需求,如超时控制,可以考虑使用 context 包配合 WaitGroup。
基本上就这些。WaitGroup 虽小,但在并发控制中非常实用,掌握它的正确用法能让 Go 并发编程更安全高效。
以上就是Golang WaitGroup如何管理多个协程的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号