匿名函数与输出顺序之谜
在 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 语言中匿名函数执行顺序为何与预期不符?的详细内容,更多请关注php中文网其它相关文章!