Go 语言中匿名函数执行顺序为何与预期不符?

Go 语言中匿名函数执行顺序为何与预期不符?

匿名函数与输出顺序之谜

在 go 语言中,匿名函数的执行顺序与您预期的可能不一致。让我们通过一个例子来探索这种情况。

代码:

package main

import (
    "fmt"
)

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

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

    fmt.println("hello world, sdd")
}

预期执行顺序:

  • 匿名函数输出 "sdd"
  • 主函数输出 "hello world, sdd"

实际执行顺序:

有时为:

  • "hello world, sdd"
  • "sdd"

其他时候为:

  • "sdd"
  • "hello world, sdd"

原因:

这种执行顺序差异的原因在于 fmt.println 函数和匿名函数都会向不同的流中输出数据。fmt.println 输出到标准输出流,而匿名函数输出到标准错误流。这两个流什么时候向屏幕显示取决于操作系统调度。

尽管匿名函数先执行,但它们写入标准错误流,而 fmt.println 写入标准输出流。因此,输出顺序取决于两个流何时被调度打印到屏幕。

您可以在代码中添加如下内容来确认匿名函数确实在 fmt.println 之前执行:

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

    func() {
        fmt.Println(tss)
        i++
        fmt.Println("i is", i) // 添加此行
    }()

    fmt.Println("hello world, sdd")
}

无论 fmt.println 或匿名函数先输出什么,您都会看到 i is 2,表明匿名函数已先于 fmt.println 执行。

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