代码拉取完成,页面将自动刷新
package go_concurrent
import "sync"
type conFunc struct {
fs []func()
wg *sync.WaitGroup
}
func ConcurrentFunc(f ...func()) *conFunc {
return &conFunc{
fs: f,
wg: new(sync.WaitGroup),
}
}
func (cf *conFunc) Add(f func()) {
cf.fs = append(cf.fs, f)
}
func (cf *conFunc) Aggregate(rf func()) {
n := len(cf.fs)
cf.wg.Add(n)
for _, f := range cf.fs {
go func(f func()) {
defer cf.wg.Done()
f()
}(f)
}
cf.wg.Wait()
rf()
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。