go waitgroup

package main

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

func process(i int, wg *sync.WaitGroup) {
	fmt.Println("started Goroutine ", i)
	time.Sleep(2 * time.Second)
	fmt.Printf("Goroutine %d ended\n", i)
	wg.Done() // wg-1
}
func main() {
	no := 3
	var wg sync.WaitGroup // 注意sync.WaitGroup是一个结构体, 传参数时注意
	//wg.Wait()
	fmt.Println("wait return")
	fmt.Printf("wait return 你好啊 %d\n", no)
	for i := 0; i < no; i++ {
		wg.Add(1)
		go process(i, &wg) // 传参数是地址
	}
	wg.Wait() //wg相当于一个计数,起一个goroutine时,wg+1当, 结束wg.Done(), wg-1,wg=0时,返回wg.Wait()
	fmt.Println("All go routines finished executing")
}
posted @   ty1539  阅读(27)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
点击右上角即可分享
微信分享提示