117.info
人生若只如初见

Go WaitGroup的使用方式及实例详解

WaitGroup 是 Go 语言的一个并发控制机制,它可以用于等待一组 goroutine 的结束。WaitGroup 提供了三个方法:Add、Done 和 Wait。

  1. Add 方法:用于设置 WaitGroup 中等待的 goroutine 的数量。Add 方法的参数是一个整数,表示需要等待的 goroutine 的数量。通常在启动每个 goroutine 之前都会调用 Add 方法来增加要等待的 goroutine 的数量。

  2. Done 方法:用于通知 WaitGroup 一个 goroutine 的结束。在 goroutine 的最后调用 Done 方法来减少 WaitGroup 中等待的 goroutine 的数量。

  3. Wait 方法:用于阻塞当前 goroutine,直到 WaitGroup 中等待的 goroutine 的数量变为 0。一般在主 goroutine 里调用 Wait 方法,等待所有子 goroutine 结束后再继续执行。

下面是一个使用 WaitGroup 的示例代码:

package main
import (
"fmt"
"sync"
)
func main() {
var wg sync.WaitGroup
for i := 0; i < 5; i++ {
wg.Add(1)
go func(i int) {
defer wg.Done()
fmt.Printf("goroutine %d\n", i)
}(i)
}
wg.Wait()
fmt.Println("All goroutines finished")
}

在上面的例子中,首先创建了一个 WaitGroup 对象 wg。然后使用一个 for 循环启动了 5 个 goroutine,并在每个 goroutine 中调用了 wg.Add(1) 来增加 WaitGroup 中等待的 goroutine 的数量。在每个 goroutine 的最后调用了 wg.Done() 来通知 WaitGroup 一个 goroutine 的结束。最后在主 goroutine 中调用了 wg.Wait() 来等待所有的子 goroutine 结束。

上面的代码运行时,可能会输出类似如下的结果:

goroutine 4
goroutine 0
goroutine 3
goroutine 2
goroutine 1
All goroutines finished

可以看到,不同的 goroutine 的输出顺序是随机的,这是因为它们是并发执行的。

总结:WaitGroup 是 Go 语言中一个用于等待一组 goroutine 结束的机制。通过调用 Add、Done 和 Wait 方法,可以实现对一组 goroutine 的并发控制。

未经允许不得转载 » 本文链接:https://www.117.info/ask/feaa9AzsLBAZTAVw.html

推荐文章

  • 如何处理Go语言中的并发网络请求的流量控制问题

    在Go语言中处理并发网络请求的流量控制问题,可以使用以下方法: 使用Go的goroutine和channel机制:通过创建goroutine来处理并发请求,并使用channel来控制并发量...

  • Go语言中如何处理并发编程的问题

    在Go语言中,可以使用goroutine和channel来处理并发编程的问题。 Goroutine:Goroutine是Go语言中轻量级的线程,可以在程序中创建多个Goroutine同时执行不同的任...

  • 如何处理Go语言中的并发任务的任务丢失和任务重复问题

    在Go语言中,可以使用以下几种方法来处理并发任务的任务丢失和任务重复问题: 使用带缓冲的通道:可以使用带缓冲的通道来存储任务,当任务到达时,先将任务放入通...

  • 在Go语言中如何解决并发任务的监控和调优问题

    在Go语言中,可以使用以下方法来解决并发任务的监控和调优问题: 使用goroutine和channel:Go语言中的goroutine可以轻松地创建并发任务,而channel则可以用于协调...

  • PHP chdir()函数的作用是什么

    PHP中的chdir()函数用于改变当前工作目录。它的作用是将当前工作目录更改为指定的目录。这在需要在脚本中访问其他目录的文件时非常有用。使用chdir()函数可以实现...

  • 提高Go语言应用程序性能的关键:内存优化和垃圾回收技巧

    提高Go语言应用程序性能的关键主要包括内存优化和垃圾回收技巧。下面是一些具体的建议: 使用合适的数据结构:Go语言提供了丰富的数据结构,选择合适的数据结构可...

  • mysql索引唯一性检查的方法是什么

    MySQL索引的唯一性检查是通过在创建索引时指定UNIQUE关键字来实现的。具体步骤如下:1. 首先,使用CREATE TABLE语句创建一个表,其中包含要创建唯一索引的列。2....

  • oracle怎么快速导入csv数据

    要快速导入CSV数据到Oracle,可以使用以下步骤:1. 首先,创建一个表来存储CSV数据。可以使用Oracle SQL Developer或SQL*Plus等工具连接到Oracle数据库,并使用C...