Go语言同步等待组sync.WaitGroup结构体对象方法详解
sync.WaitGroup结构体对象
在Go语言中,sync.WaitGroup结构体对象用于等待一组线程的结束;WaitGroup是go并发中最常用的工具,我们可以通过WaitGroup来表达这一组协程的任务是否完成,以决定是否继续往下走,或者取任务结果;
WaitGroup的结构体
结构如下所示:
type WaitGroup struct {
noCopy noCopy
state1 [3]uint32
}
在sync.WaitGroup结构体对象中有三个方法,Add()、Done()、Wait()
Add()方法
主要为WaitGroup的等待数+1或者+n;
Add()方法的定义如下:
func(*WaitGroup) Add()
- Add()方法内部计数器加上delta,delta可以是负数;
- 如果内部计数器变为0,则Wait()方法会将处于阻塞等待的所有goroutine释放;
- 如果计数器小于0,则调用panic()函数;
- Add()方法加上正数的调用应在Wait()方法之前,否则Wait()方法可能只会等待很少的goroutine;
- Add()方法在创建新的goroutine或者其它等待的事件之前调用;
Done()方法
Done函数调用的也是Add函数,主要用于-1操作;
Done()方法的定义如下:
func(wg *WaitGroup) Done()
- Done()方法会减少WaitGroup计数器的值,一般在goroutine的最后执行;
Wait()方法
阻塞当前协程,直到等待数归为0才继续向下执行;
Wait()方法的定义如下:
func (wg *WaitGroup) Wait()
Wait()方法会阻塞,知道WaitGroup计数器减为0.
Add()、Done()、Wait()三者对比
- 在三个方法中,使用Add()方法添加计数,使用Done()方法减掉一个计数,如果计数不为0,则会阻塞Wait()方法的运行;
- 一个goroutine调用Add()方法来设定等待的goroutine的数量;
- 每个被等待的goroutine在结束时调用Done()方法;
- 在主goroutine里可以调用Wait()方法阻塞至所有goroutine结束;
sync.WaitGroup使用示例
使用sync.WaitGroup等待goroutine结束的示例如下图所示:

以上就是Go语言同步等待组sync.WaitGroup结构体对象方法详解的详细内容,更多关于Go sync.WaitGroup结构体的资料请关注脚本之家其它相关文章!
相关文章
实时通信的服务器推送机制 EventSource(SSE) 简介附go实现示例代码
EventSource是一种非常有用的 API,适用于许多实时应用场景,它提供了一种简单而可靠的方式来建立服务器推送连接,并实现实时更新和通知,这篇文章主要介绍了实时通信的服务器推送机制 EventSource(SSE)简介附go实现示例,需要的朋友可以参考下2024-03-03
Golang 使用os 库的 ReadFile() 读文件最佳实践
这篇文章主要介绍了Golang使用os库的ReadFile()读文件最佳实践,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下2022-09-09


最新评论