Golang高并发控制利器-errgroup

706 阅读2分钟

志不真则心不热,心不热则功不紧。——颜元

1. 前言

说起如今的SJ政策,大家都发表了各自的看法,但是我在这里明确说下:只要教育在,培训行业一定会在,只不过以不同的形式运行罢了,谁都不希望自己的孩子输在教育的起跑线上,你家孩子不上课,人家孩子疯狂报班学习利用寒暑假或者周中,最后蒙蔽的永远是那些看不到这政策背后的因,只看到眼前的果(终于大家一样了)。所以刚需在,教培一定在。

2. 容易写的高并发控制技术

闲话不多说,直接上干货

我们之前写一个多goroutine的时候一般都会选择sync下面的WaitGroup,比如:

  wg := sync.WaitGroup{}
  for i:=0; i<10; i++ {
     wg.Add(1)
     go func() {
        defer wg.Done()
   }()
  }
  wg.Wait()

但是这样会有问题,就是当我们想要知道某个goroutine报什么错误的时候发现很难,因为我们是直接go func(){}出去的,并没有返回值,因此对需要接受返回值做进一步处理的需求就无法满足了。

3. errgroup他来了

这是google对go的一个扩展包:

golang.org/x/sync/errgroup 它可以帮助我们实现当有一个goroutine执行报错的时候,通过wait可以获取到错误,然后执行相应的操作,如下:

  group, _ := errgroup.WithContext(context.Background())
  group.Go(func() error {
   defer func() {
    //recover
   }()
   //TODO:真正逻辑
  })
  if err := group.Wait(); err != nil {
   return nil, err
  }

这样当有一个或者多个goroutine报错的时候,我们可以轻松的获取err信息,然后做相应的后续操作,你看这样是不很方便呢?

4. 小结

欢迎大家转发和投稿哈,每天坚持学习一点点,社会就会对你好一点点,不要被外部的因素所影响,坚持做自己认为对的事情,加油。

5. 关注公众号

扫码_搜索联合传播样式-标准色版.png