How to wait for Goroutines to Finish Execution?
The WaitGroup type of sync package, is used to wait for the program to finish all goroutines launched from the main function. It uses a counter that specifies the number of goroutines, and Wait blocks the execution of the program until the WaitGroup counter is zero.
The Add method is used to add a counter to the WaitGroup.
The Done method of WaitGroup is scheduled using a defer statement to decrement the WaitGroup counter.
The Wait method of the WaitGroup type waits for the program to finish all goroutines.
The Wait method is called inside the main function, which blocks execution until the WaitGroup counter reaches the value of zero and ensures that all goroutines are executed.
Example
package main
import (
"fmt"
"io/ioutil"
"log"
"net/http"
"sync"
)
// WaitGroup is used to wait for the program to finish goroutines.
var wg sync.WaitGroup
func responseSize(url string) {
// Schedule the call to WaitGroup's Done to tell goroutine is completed.
defer wg.Done()
fmt.Println("Step1: ", url)
response, err := http.Get(url)
if err != nil {
log.Fatal(err)
}
fmt.Println("Step2: ", url)
defer response.Body.Close()
fmt.Println("Step3: ", url)
body, err := ioutil.ReadAll(response.Body)
if err != nil {
log.Fatal(err)
}
fmt.Println("Step4: ", len(body))
}
func main() {
// Add a count of three, one for each goroutine.
wg.Add(3)
fmt.Println("Start Goroutines")
go responseSize("https://www.golangprograms.com")
go responseSize("https://stackoverflow.com")
go responseSize("https://coderwall.com")
// Wait for the goroutines to finish.
wg.Wait()
fmt.Println("Terminating Program")
}
Output
Start Goroutines
Step1: https://coderwall.com
Step1: https://www.golangprograms.com
Step1: https://stackoverflow.com
Step2: https://stackoverflow.com
Step3: https://stackoverflow.com
Step4: 116749
Step2: https://www.golangprograms.com
Step3: https://www.golangprograms.com
Step4: 79801
Step2: https://coderwall.com
Step3: https://coderwall.com
Step4: 203842
Terminating Program
Most Helpful This Week
What is a Goroutine?
How to fix race condition using Atomic Functions in Golang?
How to kill execution of goroutine?
How to create goroutines in Golang?
How to use a mutex to define critical sections of code and fix race conditions?
How to play and pause execution of goroutine?
Catch values from Goroutines