golang会取代python吗_golang中的WaitGroup与Python之类的其他语言相比是否向后退步?...

据我所知,够程需要有参考WaitGroup对象调用完成(),这意味着,我必须要么使够程接受WaitGroup对象,或使WaitGroup对象全局该goroutine。

我不同意WaitGroup与其他语言相比是一个倒退。我真的很喜欢它的简单。但是,我确实同意传递WaitGroup对象意味着并发逻辑将与您的业务逻辑混合在一起,而我不喜欢这种情况。

所以我想出了这个通用的功能来解决这个问题对我来说:

// Parallelize parallelizes the function calls

func Parallelize(functions ...func()) {

var waitGroup sync.WaitGroup

waitGroup.Add(len(functions))

defer waitGroup.Wait()

for _, function := range functions {

go func(copy func()) {

defer waitGroup.Done()

copy()

}(function)

}

}

下面是一个例子:

func1 := func() {

for char := 'a'; char < 'a' + 3; char++ {

fmt.Printf("%c ", char)

}

}

func2 := func() {

for number := 1; number < 4; number++ {

fmt.Printf("%d ", number)

}

}

Parallelize(func1, func2) // a 1 b 2 c 3

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值