GolangWaitGroup使用教程:并发同步全解析
时间:2025-06-28 13:27:12 218浏览 收藏
小伙伴们有没有觉得学习Golang很有意思?有意思就对了!今天就给大家带来《Golang中WaitGroup怎么用?并发任务同步详解》,以下内容将会涉及到,若是在学习中对其中部分知识点有疑问,或许看了本文就能帮到你!
WaitGroup死锁通常由Add()和Done()调用不匹配或重复使用导致。要避免死锁,需确保三点:1. 启动goroutine前调用Add(1),并在对应goroutine末尾使用defer wg.Done()保证成对执行;2. 避免在Wait()之后再次调用Add(),应一次性使用WaitGroup,重复需求需新建实例;3. Add()参数不得使计数器为负,否则引发panic。此外,Golang同步机制还包括Mutex、RWMutex、Channel、Cond和Atomic,适用于不同并发场景。
WaitGroup是Golang中用于等待一组goroutine完成的同步机制。你可以把它想象成一个计数器,主goroutine等待这个计数器归零。

WaitGroup的核心在于三个方法:Add(delta int)
、Done()
和Wait()
。Add()
增加计数器的值,Done()
减少计数器的值,Wait()
阻塞直到计数器归零。

package main import ( "fmt" "sync" "time" ) func worker(id int, wg *sync.WaitGroup) { defer wg.Done() // 确保goroutine结束时计数器减一 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) // 启动一个goroutine,计数器加一 go worker(i, &wg) } wg.Wait() // 等待所有goroutine完成 fmt.Println("All workers done!") }
如何避免WaitGroup使用中的常见死锁?
死锁往往发生在Add()
和Done()
调用不匹配的时候。例如,Add()
的调用次数少于实际启动的goroutine数量,或者Done()
被调用次数多于Add()
的调用次数。前者会导致Wait()
永久阻塞,后者会导致panic。
避免死锁的关键在于确保Add()
和Done()
的调用次数严格匹配。一种好的做法是在启动goroutine之前立即调用Add()
,并在goroutine结束时立即调用Done()
。可以使用defer
关键字来确保Done()
一定会被执行,即使goroutine发生panic。

另一种可能导致死锁的情况是在Wait()
之后再次调用Add()
。WaitGroup的设计初衷是一次性的,不应该重复使用。如果需要重复使用,应该创建一个新的WaitGroup实例。
WaitGroup的Add方法参数为负数会发生什么?
Add()
方法接受一个整数参数,表示计数器需要增加的值。如果传递一个负数,实际上是减少计数器的值。如果计数器变为负数,会引发panic。
package main import ( "fmt" "sync" ) func main() { var wg sync.WaitGroup wg.Add(1) wg.Done() // 计数器变为0 wg.Add(-2) // 计数器变为-2,会panic fmt.Println("This line will not be printed") }
因此,在使用Add()
方法时,务必确保传递的参数不会导致计数器变为负数。
除了WaitGroup,Golang还有哪些同步机制?
除了WaitGroup,Golang还提供了其他的同步机制,例如:
- Mutex (互斥锁): 用于保护共享资源,防止多个goroutine同时访问。
- RWMutex (读写锁): 允许多个goroutine同时读取共享资源,但只允许一个goroutine写入。
- Channel (通道): 用于goroutine之间的通信和同步。
- Cond (条件变量): 用于goroutine在满足特定条件时进行等待和唤醒。
- Atomic (原子操作): 用于对基本数据类型进行原子操作,避免数据竞争。
选择哪种同步机制取决于具体的应用场景。WaitGroup适用于等待一组goroutine完成,Mutex和RWMutex适用于保护共享资源,Channel适用于goroutine之间的通信,Cond适用于复杂的条件同步,Atomic适用于简单的原子操作。选择合适的同步机制可以提高程序的性能和可靠性。
终于介绍完啦!小伙伴们,这篇关于《GolangWaitGroup使用教程:并发同步全解析》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布Golang相关知识,快来关注吧!
-
505 收藏
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
243 收藏
-
185 收藏
-
318 收藏
-
348 收藏
-
167 收藏
-
435 收藏
-
158 收藏
-
378 收藏
-
369 收藏
-
119 收藏
-
205 收藏
-
365 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习