Go例程在for循环中的奇怪行为

问题描述

我正在从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)
    }()
 }