package main
import (
"fmt"
"sync"
"time"
)
func main() {
wg := sync.WaitGroup{}
c := make(chan struct{})
for i := 0; i < 10; i++ {
wg.Add(1)
go func(num int, close <-chan struct{}) {
defer wg.Done()
<-close
fmt.Println(num)
}(i, c)
}
if WaitTimeout(&wg, time.Second*5) {
close(c)
fmt.Println("timeout exit")
}
fmt.Println("WaitTimeout执行完了")
time.Sleep(time.Second * 10)
}
func WaitTimeout(wg *sync.WaitGroup, timeout time.Duration) bool {
ch := make(chan bool)
go time.AfterFunc(timeout, func() {
fmt.Println(timeout,"过去了")
ch <- true
})
go func() {
wg.Wait()
ch <- false
}()
return <-ch
}
为 sync.WaitGroup 中 Wait 函数⽀持 WaitTimeout 功能
最新推荐文章于 2024-10-17 20:29:41 发布
本文介绍了一个使用Go语言实现的并发程序,通过sync.WaitGroup管理10个goroutine,每个goroutine在接收到channel关闭信号后结束。还展示了如何设置超时时间来控制整个进程的执行。
摘要由CSDN通过智能技术生成