search
HomeBackend DevelopmentGolangWhat are WaitGroups in go language? how to use?

What are WaitGroups in go language? how to use?

Mar 17, 2023 pm 08:09 PM
gogolanggo languagewaitgroups

What are WaitGroups? The following article will take you to understand WaitGroups in the go language and introduce how to use WaitGroups. I hope it will be helpful to you!

What are WaitGroups in go language? how to use?

#What are WaitGroups?

WaitGroups is an efficient way to synchronize your goroutines. Imagine you are traveling by car with your family. Your dad stops at a strip mall or fast food restaurant to buy some food and use the bathroom. You'd better want to wait until everyone gets back before driving to Horizon. WaitGroups helps you do this.

WaitGroups is defined by calling the sync package in the standard library.

var wg sync.WaitGroup

So, what is WaitGroup? WaitGroup is a structure that contains certain information about how many goroutine the program needs to wait for. It is a group containing the number of goroutines you need to wait for.

WaitGroups has three most important methods: Add, Done and Wait.

  • Add: Add to the total number of goroutines you need to wait for.
  • Done: Subtract one from the total number of goroutines you need to wait for.
  • Wait: Blocks the code from continuing until there are no more goroutines to wait for.

How to use WaitGroups

Let’s take a look at a piece of code:

package main

import (
    "fmt"
    "sync"
    "time"
)

func main() {
    var wg sync.WaitGroup
    wg.Add(1)

    go func() {
        defer wg.Done()

        fmt.Println(time.Now(), "start")
        time.Sleep(time.Second)
        fmt.Println(time.Now(), "done")
    }()

    wg.Wait()
    fmt.Println(time.Now(), "exiting...")
}
2022-08-21 17:01:54.184744229 +0900 KST m=+0.000021800 start
2022-08-21 17:01:55.184932851 +0900 KST m=+1.000210473 done
2022-08-21 17:01:55.18507731 +0900 KST m=+1.000354912 exiting...
  • We first initialize a WaitGroup Instance of wg.
  • Then we add 1 to wg because we want to wait for a goroutine to complete.
  • Then we run this goroutine. Inside the goroutine, we make a delayed call to wg.Done() to ensure that we decrement the number of goroutine to wait for. If we don't do this, then the code will wait forever for the goroutine to complete and will cause a deadlock.
  • After the goroutine call, we want to make sure to block the code until WaitGroup is empty. We do this by calling wg.Wait().

Why use WaitGroups instead of channels?

Now that we know how to use WaitGroups, a natural thought leads us to this question: Why use WaitGroups instead of channels?

Based on my experience, there are several reasons.

  • WaitGroups tends to be more intuitive. When you read a piece of code, when you see a WaitGroup, you immediately know what the code is doing. The method names are clear and get to the point. However, with channels, sometimes it's not so clear. Using channels is smart, but when you read a complex piece of code, it can be cumbersome to understand.
  • Sometimes, you don't need to use channels. For example, let's take a look at this code:
 var wg sync.WaitGroup

  for i := 0; i < 5; i++ {
      wg.Add(1)
      go func() {
          defer wg.Done()

          fmt.Println(time.Now(), "start")
          time.Sleep(time.Second)
          fmt.Println(time.Now(), "done")
      }()
  }

  wg.Wait()
  fmt.Println(time.Now(), "exiting...")

You can see that this goroutine does not communicate data with other goroutine. If your goroutine is a one-time job and you don't need to know the result, using WaitGroup is preferable. Now look at this code:

  ch := make(chan int)

  for i := 0; i < 5; i++ {
      go func() {
          randomInt := rand.Intn(10)
          ch <- randomInt
      }()
  }

  for i := 0; i < 5; i++ {
      fmt.Println(<-ch)
  }

Here, goroutine is sending data to channel. In these cases we don't need to use WaitGroup as that would be redundant. If the receive has already done enough blocking, why wait for the goroutine to complete?

WaitGroups is specially used to handle waiting for goroutines. I think the main purpose of channels is to communicate data. You can't use WaitGroup to send and receive data, but you can use a channel to synchronize your goroutines.

Finally, there is no right answer. I know this can be annoying, but it depends on you and the team you work for. Whatever method is best, no answer is wrong. I personally prefer to use WaitGroups for synchronization, but your situation may be different. Choose what feels most intuitive to you.

One thing to note

Sometimes, you may need to pass a WaitGroup instance to a goroutine. There may be several WaitGroup to handle different goroutine, or it may be a design choice. Whatever the reason, make sure to pass a pointer to WaitGroup, like this:

var wg sync.WaitGroup

for i := 0; i < 5; i++ {
    wg.Add(1)
    go func(wg *sync.WaitGroup) {
        defer wg.Done()

        fmt.Println(time.Now(), "start")
        time.Sleep(time.Second)
        fmt.Println(time.Now(), "done")
    }(&wg)
}

wg.Wait()
fmt.Println(time.Now(), "exiting...")

The reason is that Go is a pass-by-value language. This means that whenever you pass an argument to a function, Go copies the argument and passes it instead of the original object. What happens in this case is that the entire WaitGroup object will be copied, which means that the goroutine will handle a completely different WaitGroup. wg.Done() does not subtract from the original wg, but subtracts a copy of it, which only exists in goroutine.

Summary

By using WaitGroups, we can easily synchronize goroutines, ensuring that our code is executed at the correct time. Although channels can also be used for synchronization, WaitGroups are generally more intuitive and easier to read. When using WaitGroup, be sure to pass the pointer to WaitGroup correctly to prevent copy issues. No matter which method you choose, choose the one that's most intuitive and works best for you and your team.

Recommended learning: Golang tutorial

The above is the detailed content of What are WaitGroups in go language? how to use?. For more information, please follow other related articles on the PHP Chinese website!

Statement
This article is reproduced at:掘金社区. If there is any infringement, please contact admin@php.cn delete
Golang vs. Python: The Pros and ConsGolang vs. Python: The Pros and ConsApr 21, 2025 am 12:17 AM

Golangisidealforbuildingscalablesystemsduetoitsefficiencyandconcurrency,whilePythonexcelsinquickscriptinganddataanalysisduetoitssimplicityandvastecosystem.Golang'sdesignencouragesclean,readablecodeanditsgoroutinesenableefficientconcurrentoperations,t

Golang and C  : Concurrency vs. Raw SpeedGolang and C : Concurrency vs. Raw SpeedApr 21, 2025 am 12:16 AM

Golang is better than C in concurrency, while C is better than Golang in raw speed. 1) Golang achieves efficient concurrency through goroutine and channel, which is suitable for handling a large number of concurrent tasks. 2)C Through compiler optimization and standard library, it provides high performance close to hardware, suitable for applications that require extreme optimization.

Why Use Golang? Benefits and Advantages ExplainedWhy Use Golang? Benefits and Advantages ExplainedApr 21, 2025 am 12:15 AM

Reasons for choosing Golang include: 1) high concurrency performance, 2) static type system, 3) garbage collection mechanism, 4) rich standard libraries and ecosystems, which make it an ideal choice for developing efficient and reliable software.

Golang vs. C  : Performance and Speed ComparisonGolang vs. C : Performance and Speed ComparisonApr 21, 2025 am 12:13 AM

Golang is suitable for rapid development and concurrent scenarios, and C is suitable for scenarios where extreme performance and low-level control are required. 1) Golang improves performance through garbage collection and concurrency mechanisms, and is suitable for high-concurrency Web service development. 2) C achieves the ultimate performance through manual memory management and compiler optimization, and is suitable for embedded system development.

Is Golang Faster Than C  ? Exploring the LimitsIs Golang Faster Than C ? Exploring the LimitsApr 20, 2025 am 12:19 AM

Golang performs better in compilation time and concurrent processing, while C has more advantages in running speed and memory management. 1.Golang has fast compilation speed and is suitable for rapid development. 2.C runs fast and is suitable for performance-critical applications. 3. Golang is simple and efficient in concurrent processing, suitable for concurrent programming. 4.C Manual memory management provides higher performance, but increases development complexity.

Golang: From Web Services to System ProgrammingGolang: From Web Services to System ProgrammingApr 20, 2025 am 12:18 AM

Golang's application in web services and system programming is mainly reflected in its simplicity, efficiency and concurrency. 1) In web services, Golang supports the creation of high-performance web applications and APIs through powerful HTTP libraries and concurrent processing capabilities. 2) In system programming, Golang uses features close to hardware and compatibility with C language to be suitable for operating system development and embedded systems.

Golang vs. C  : Benchmarks and Real-World PerformanceGolang vs. C : Benchmarks and Real-World PerformanceApr 20, 2025 am 12:18 AM

Golang and C have their own advantages and disadvantages in performance comparison: 1. Golang is suitable for high concurrency and rapid development, but garbage collection may affect performance; 2.C provides higher performance and hardware control, but has high development complexity. When making a choice, you need to consider project requirements and team skills in a comprehensive way.

Golang vs. Python: A Comparative AnalysisGolang vs. Python: A Comparative AnalysisApr 20, 2025 am 12:17 AM

Golang is suitable for high-performance and concurrent programming scenarios, while Python is suitable for rapid development and data processing. 1.Golang emphasizes simplicity and efficiency, and is suitable for back-end services and microservices. 2. Python is known for its concise syntax and rich libraries, suitable for data science and machine learning.

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

MantisBT

MantisBT

Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

PhpStorm Mac version

PhpStorm Mac version

The latest (2018.2.1) professional PHP integrated development tool

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

mPDF

mPDF

mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Powerful PHP integrated development environment