开发过程中,经常遇到task之间的同步问题。例如,多个子task并发完成一部分任务,主task等待他们最后结束。

在Go语言,实现同步的一种方式就是WaitGroup。

Example

package main 

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



func main() {

	var wg sync.WaitGroup


	wg.Add(3)
	go func(n int){
		fmt.Println("n:", n)
		t := time.Duration(n)*time.Second
		time.Sleep(t)

		wg.Done()
	}(1)


	go func(n int){
		fmt.Println("n:", n)
		t := time.Duration(n)*time.Second
		time.Sleep(t)
		time.Sleep(t)

		wg.Done()
	}(2)

	go func(n int){
		fmt.Println("n:", n)
		t := time.Duration(n)*time.Second
		time.Sleep(t)

		wg.Done()
	}(3)

	wg.Wait()

	fmt.Println("main exit...")
}


output:

n: 3

n: 1

n: 2

main exit...

注意

WaitGroup变量定义后,是不允许被拷贝的,即不允许作为函数参数或者赋值给其他变量。

相关文章:

  • 2021-07-05
  • 2021-12-20
  • 2022-12-23
  • 2021-07-19
  • 2021-06-07
  • 2022-12-23
  • 2022-12-23
  • 2021-10-20
猜你喜欢
  • 2021-10-06
  • 2022-02-16
  • 2021-11-21
  • 2022-12-23
  • 2021-06-10
  • 2021-12-24
  • 2023-01-30
相关资源
相似解决方案