首页 > 解决方案 > Golang chan & waitgroup 有时要等很久?

问题描述

我是新的golang。我写了一个并行请求代码但有时会发生等待很长时间。你知道什么原因吗?

var wg sync.WaitGroup
    guard := make(chan struct{}, 50)

    for _, li := range results {
       wg.Add(1)
       guard <- struct{}{}
       go func(){
        defer func(){//I'm afraid some panic, so I use defer func, make sure it has done.
            wg.Done()
            <-guard
         }()
          //some biz code 
          //http requests
       }()
    }
    wg.Wait()

我尝试打印进程号,观察者号,总是卡在最后一个进程很长时间。我不知道卡住的原因。可以完成,只是在最后一个过程中卡了很久。

标签: goparallel-processingchannel

解决方案


推荐阅读