golang sync.WaitGroup 在for循环内取值错误


本文摘自网络,作者,侵删。

背景:需要for循环传不同的参数请求同一个接口得到数据。
吐槽:那为什么不能改一下接口,传多类型一次返回数据?老项目能用则用,动一动锅从天上来。

很多个请求都先后发出,所有请求都回来我们再处理所有结果,正好 sync.WaitGroup能满足我们的需求。

网上一顿搜索终于实现了,但出了一个BUG,for循环上的值和在go func使用会被覆盖。

有问题的代码

// 咔咔一顿操作
result := []string{}
group := &sync.WaitGroup{}
for dataKey, dataVal := range dataMap {
    // 咔咔一顿操作
    group.Add(1)
    go func() {
        defer group.Done()
        // 咔咔一顿操作
        // 使用dataKey和dataVal去请求接口
        // 咔咔一顿操作
        result = append(result, dataResp)
    }()
}
group.Wait()
//result 就是我们要的结果
// 咔咔一顿操作

发现去请求接口使用dataKey和dataVal的有重复,就是dataMap里存了多个相同的key和val一样,经排查dataMap数据没有问题,是for循环代码出了问题,最终使用下面代码,将dataKey, dataVal 传入go func即可解决。

// 咔咔一顿操作
result := []string{}
group := &sync.WaitGroup{}
for dataKey, dataVal := range dataMap {
    // 咔咔一顿操作
    group.Add(1)
    go func(dataKey int, dataVal string) {
        defer group.Done()
        // 咔咔一顿操作
        // 使用dataKey和dataVal去请求接口
        // 咔咔一顿操作
        result = append(result, dataVal)
    }(dataKey,dataVal)
}
group.Wait()
//result 就是我们要的结果
// 咔咔一顿操作

特别详细的原因还没来得及研究,记录一下踩坑。


本文来自:简书

感谢作者:東玖零

查看原文:golang sync.WaitGroup 在for循环内取值错误

相关阅读 >>

Go关于tpl文件无法读取域中数据{{$.name}}

Go语言中Goto的用法是什么

Golang和Go是一样的吗

为什么我们从 docker 转向了 Go

Go使用iris问题之数字变科学计数法

关于Golang-import导入包语法

Golang程序设计——函数

解析Golang iris怎么使用

Golang怎么编写一个window定时关机

一文读懂云原生 Go-zero 微服务框架

更多相关阅读请进入《Go》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...