问题描述
我正在从Python切换到GoLang。我正在学习goroutines。在for循环中使用goroutines时,我会遇到奇怪的输出。
package main
import "fmt"
func main() {
var test = []int{1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40}
for _,x := range test{
go func() {
fmt.Println(x)
}()
}
}
输出:
25
19
28
19
40
40
6
我当时以为它是从for循环中获取值,但是当我看到它在增加和减少时。我很困惑。为什么会这样?
解决方法
goroutine正在访问x
变量,该变量与goroutine的执行并行地改变。我认为这是一个常见的问题,我认为甚至至少要去程序员一次。您可以像这样捕获变量的当前值:
for _,x := range test{
go func(x int) {
fmt.Println(x)
}(x)
}
或者像这样:
for _,x := range test{
x2 := x
go func() {
fmt.Println(x2)
}()
}