WaitGroup用于协调多个goroutine的完成,通过Add增加计数、Done减少计数、Wait阻塞等待归零。示例中三个worker并发执行,主协程等待它们完成后再退出。需注意Add在goroutine外调用、传递指针、Add与Done匹配,避免重复Wait。适用于批量任务同步场景。

在Go语言中,WaitGroup 是 sync 包提供的同步原语之一,用于等待一组并发的协程(goroutine)完成任务。它特别适用于主协程需要等待其他多个子协程执行完毕后再继续的场景。
WaitGroup 内部维护一个计数器:
通过这三个方法,可以协调主协程和其他协程的生命周期,避免程序提前退出或资源竞争。
以下是一个简单的例子,展示如何使用 WaitGroup 等待多个协程完成:
立即学习“go语言免费学习笔记(深入)”;
package main
<p>import (
"fmt"
"sync"
"time"
)</p><p>func worker(id int, wg <em>sync.WaitGroup) {
defer wg.Done() // 任务完成,计数器减1
fmt.Printf("Worker %d starting\n", id)
time.Sleep(2 </em> time.Second)
fmt.Printf("Worker %d done\n", id)
}</p><p>func main() {
var wg sync.WaitGroup</p><pre class="brush:php;toolbar:false;"><pre class="brush:php;toolbar:false;">for i := 1; i <= 3; i++ {
wg.Add(1) // 每启动一个协程,计数器加1
go worker(i, &wg) // 启动协程
}
wg.Wait() // 主协程等待所有协程完成
fmt.Println("All workers finished")}
输出结果类似:
Worker 1 starting Worker 2 starting Worker 3 starting Worker 1 done Worker 2 done Worker 3 done All workers finished
使用 WaitGroup 时需注意以下几点,避免常见错误:
WaitGroup 常用于以下情况:
基本上就这些。WaitGroup 使用简单,但对协程生命周期管理非常有效。只要注意调用时机和同步方式,就能写出稳定高效的并发代码。
以上就是Golang如何使用WaitGroup管理协程生命周期的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号