相同代码goland编辑器和命令行 go run 结果不同

发布于 09-11 22:59 字数 605 浏览 19 评论 0

相同代码goland编辑器和命令行 go run 结果不同

代码如下:

package main

import "fmt"

func main() {
    testDefer()
}

func testDefer() {
    defer func() {
        fmt.Println("前")
    }()
    defer func() {
        fmt.Println("中")
    }()
    defer func() {
        fmt.Println("后")
    }()

    panic("系统异常")
}

运行结果
goland

image.png

命令行

image.png

goland 究竟出了什么问题, 开发过程中应该怎么避免此类问题

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

萌无敌2022-09-18 22:59:15

你好,Golang环境 在子进程执行代码的时候,stdout ,stderr 被匿名管道重定向到父级,对响应顺序不同,触发的打印顺序也不同、 而我们在终端命令行执行, 我们的stdout,stderr 都执行同一个字符通道设备。所以是按顺序的。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文