
匿名函数与输出顺序之谜
在 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 执行。










