相同代码goland编辑器和命令行 go run 结果不同
相同代码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
命令行
goland 究竟出了什么问题, 开发过程中应该怎么避免此类问题
你好,Golang环境 在子进程执行代码的时候,stdout ,stderr 被匿名管道重定向到父级,对响应顺序不同,触发的打印顺序也不同、 而我们在终端命令行执行, 我们的stdout,stderr 都执行同一个字符通道设备。所以是按顺序的。