如何接受并发goroutine的错误

如何接受并发goroutine的错误

实现类似errgroup的功能

其实比较简单了,就是在并发goroutine的时候,我们根据初始化的goroutine的数量初始化一个chan error类型的chan,然后每个goroutine在遇到错误时候,将error写入chan,这样主goroutine通过for range去遍历这个chan就行了。

代码

package main

import (
 "errors"
 "fmt"
 "runtime"
 "sync"
)

func main() {
 ch := make(chan error, 3)
 wg := sync.WaitGroup{}
 wg.Add(3)
 go func() {
  defer wg.Done()
  ch <- errors.New("err1")
 }()
 go func() {
  defer wg.Done()
  ch <- errors.New("err2")
 }()
 go func() {
  defer wg.Done()
  ch <- errors.New("err3")
 }()

 fmt.Println(runtime.NumGoroutine(), len(ch), cap(ch))
 wg.Wait()
 close(ch)
 for err := range ch {
  fmt.Println(err)
 }
 fmt.Println(runtime.NumGoroutine(), len(ch), cap(ch))
}

结果

如何接受并发goroutine的错误

小结

还有很多方式可以实现这个功能,不过最常见的还是在waitgroup中通过chan收集error,其它方式大家下去可以自行探索。

– END –


原文始发于微信公众号(堆栈future):如何接受并发goroutine的错误

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/103500.html

(0)
小半的头像小半

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!