douxing9228 2019-09-05 02:54
浏览 161

Golang Chan&Waitgroup有时会等待很长时间?

I'm new golang. I write a parallel request code but sometimes occur wait a long time. Do you know any reason?

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()

I try print process number, observer number, always stuck the last process long time. I don't know the stuck reason. It can be finished, just stuck a long time in the last process.

  • 写回答

0条回答 默认 最新

    报告相同问题?

    悬赏问题

    • ¥15 使用C#,asp.net读取Excel文件并保存到Oracle数据库
    • ¥15 C# datagridview 单元格显示进度及值
    • ¥15 thinkphp6配合social login单点登录问题
    • ¥15 HFSS 中的 H 场图与 MATLAB 中绘制的 B1 场 部分对应不上
    • ¥15 如何在scanpy上做差异基因和通路富集?
    • ¥20 关于#硬件工程#的问题,请各位专家解答!
    • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
    • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
    • ¥30 虚心请教几个问题,小生先有礼了
    • ¥30 截图中的mathematics程序转换成matlab