在Go中,设置流程退出代码的正确方法是什么?
我尝试将主要功能更改为
func main() int { return -1 }
但这会导致错误 func main must have no arguments and no return values
func main must have no arguments and no return values
好的,所以有os.Exit(code int),但是这会立即中止该过程并且不会干净退出(例如,不执行任何递延操作)。
os.Exit(code int)
我还发现panic它将退出进程并将状态代码设置为非零,这可能是最好的方法,尽管它会将堆栈跟踪信息转储到控制台。
panic
设置退出代码的正确方法是什么?
使os.Exit最后一个延迟函数执行。延迟函数在周围函数返回之前立即执行,以相反的顺序执行。例如,
os.Exit
package main import ( "fmt" "os" ) func main() { code := 0 defer func() { os.Exit(code) }() defer func() { fmt.Println("Another deferred func") }() fmt.Println("Hello, 世界") code = 1 }
输出:
Hello, 世界 Another deferred func [process exited with non-zero status]
前往游乐场:
http://play.golang.org/p/o0LfisANwb
Go编程语言规范 推迟陈述 “ defer”语句调用一个函数,该函数的执行被推迟到周围的函数返回的那一刻,这是因为周围的函数执行了return语句,到达了函数体的末尾,或者是因为相应的goroutine正在惊慌。 DeferStmt =“ defer”表达式。 表达式必须是函数或方法调用;不能用括号括起来。内置函数的调用与表达式语句一样受到限制。 每次执行“ defer”语句时,都会照常评估调用的函数值和参数并重新保存,但实际的函数体不会执行。而是,在周围的函数返回之前立即执行延迟的函数,其顺序与延迟的相反。
Go编程语言规范
推迟陈述
“ defer”语句调用一个函数,该函数的执行被推迟到周围的函数返回的那一刻,这是因为周围的函数执行了return语句,到达了函数体的末尾,或者是因为相应的goroutine正在惊慌。
DeferStmt =“ defer”表达式。
表达式必须是函数或方法调用;不能用括号括起来。内置函数的调用与表达式语句一样受到限制。
每次执行“ defer”语句时,都会照常评估调用的函数值和参数并重新保存,但实际的函数体不会执行。而是,在周围的函数返回之前立即执行延迟的函数,其顺序与延迟的相反。