go - 从恐慌中恢复的程序未按预期退出
问题描述
据我了解,当恐慌恢复时,我希望程序退出并表现出正常行为,但事实并非如此。我期望最后一行打印“程序结束”是否正确?如果出现运行时错误,它不会被打印,是吗?
package main
import (
"fmt"
)
func main() {
defer func() {
if r := recover(); r != nil {
fmt.Printf("Cause of panic ==>>, %q\n", r)
}
}()
f(3)
fmt.Println("End of program")
}
func f(x int) {
fmt.Printf("f(%d) is called.\n", x) //panic triggered when x==0
// defer called in reverse order in case of panic
defer fmt.Printf("defer %d\n", x+0/x)
f(x-1)
}
解决方案
不会打印“程序结束”。
当检测到恐慌时,导致恐慌的函数立即返回,以及调用该函数的函数等,一直到调用的函数recover
。当该函数返回并恢复时,程序会继续运行,就好像没有发生恐慌一样。
在您的情况下,main
是恢复的功能。恐慌在f(3)
调用时触发,并且在 main 返回后进行恢复,绕过 println。
推荐阅读
- c - C、帮忙继续..?在 while 循环中 - 多项式 ADT
- python-3.x - 在python中现有的KCF跟踪器上部署opencv+cuda函数
- python - Brigthway2:如何将特定位置的 cfs 添加到 LCIA 方法
- python - 无效的登录尝试 - 尝试访问 API 时
- android - 滚动视图只有一个直接子错误
- javascript - 选择所有不包含类的按钮,多个选项
- java - Java HttpClient - 允许受限标头不起作用
- tinymce - 自定义tinymce的调色板
- sql - SQL Select min(date) group by 对应的行
- git - 如何使用 Git 查看文件在哪些提交中被重命名?