答案:sync.WaitGroup用于等待一组goroutine完成,通过Add增加计数,Done减少计数,Wait阻塞直至计数归零。示例中启动5个worker,主协程等待全部完成。

在Golang中,sync.WaitGroup 是一种常用的同步机制,用于等待一组并发的goroutine执行完成。它特别适合在主函数或主线程中启动多个子任务,并确保所有任务都结束后再继续执行后续逻辑。
示例代码:
H+是一个完全响应式,基于Bootstrap3.4.0最新版本开发的扁平化主题,她采用了左右两栏式等多种布局形式,使用了Html5+CSS3等现代技术,她提供了诸多的强大的可以重新组合的UI组件,并集成了最新的jQuery版本(2.1.1),当然,也集成了很多功能强大,用途广泛的jQuery插件,她可以用于所有的Web应用程序,如网站管理后台,网站会员中心,CMS,CRM,OA等等,当然,您也可以
433
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 <= 3; i++ {
wg.Add(1) // 增加计数
go worker(i, &wg) // 启动goroutine
}
wg.Wait() // 阻塞,直到所有worker调用Done
fmt.Println("All workers finished")
}
<code>// 错误示例
go func(wg sync.WaitGroup) { // 值传递,复制了wg
defer wg.Done()
}(wg)
go func(wg *sync.WaitGroup) {
defer wg.Done()
}(&wg)
以上就是如何在Golang中使用sync.WaitGroup等待并发完成的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号