Go语言中匿名函数执行顺序为何不确定?

go语言中匿名函数执行顺序为何不确定?

go语言中的匿名函数执行疑云

go语言中,匿名函数的执行顺序可能会令人困惑。例如,考虑以下代码:

func main() {
    tss := "sdd"
    i := 1

    func() {
        println(tss)
        i++
    }()

    fmt.println("i is", i)
}

预期执行结果为:

sdd
hello world, sdd

然而,实际执行结果可能是:

hello world, sdd
sdd

为什么会出现这种差异?

这主要是由于两个原因:

  • 流争用:go语言中,println 函数向标准错误流输出,而 fmt.println 函数向标准输出流输出。这两个流什么时候刷新并显示在屏幕上是由cpu调度决定的,因此是随机的。
  • 函数执行顺序: 匿名函数肯定是在 main 函数中 hello world, sdd 打印之前执行的。但他们的输出仅写入各自的流中,什么时候显示由流争用决定。

为了验证这一点,可以尝试以下代码:

func main() {
    tss := "sdd"
    i := 1

    func() {
        println(tss)
        i++
    }()

    fmt.println("i is", i)
}

无论哪一个流先输出,i 的值始终为 2。这表明匿名函数是在 "i is 2" 输出之前执行的,但流刷新顺序是随机的。

以上就是Go语言中匿名函数执行顺序为何不确定?的详细内容,更多请关注其它相关文章!