登录
首页 >  Golang >  Go教程

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

时间:2024-11-01 18:30:35 331浏览 收藏

各位小伙伴们,大家好呀!看看今天我又给各位带来了什么文章?本文标题《Go 语言中匿名函数执行顺序为何与预期不符? 》,很明显是关于Golang的文章哈哈哈,其中内容主要会涉及到等等,如果能帮到你,觉得很不错的话,欢迎各位多多点评和分享!

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 语言中匿名函数执行顺序为何与预期不符? 》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布Golang相关知识,快来关注吧!

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>