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循环内取值错误

相关阅读 >>

kubeedge v1.3部署指南

生产环境遇到一个 Go 问题,整组人都懵逼了...

Go 原生socket由浅入深

Golang组件化网络服务器框架halia指南

Go get命令详解

Golang后端面试汇总-001

Go好用的类型转换第三方组件

聊聊dubbo-Go-proxy的accesslogfilter

Go module 引入本地包的问题

Golang base64字符串的编码和解码

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




打赏

取消

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

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

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

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

评论

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