recover 只能捕获由 panic 引发的运行时错误且必须在 defer 中调用,无法处理普通 error 或跨协程 panic。

recover 不能捕获所有错误。它只能捕获由 panic 引发的运行时恐慌,且必须在 defer 中调用才有效。
recover 的作用范围有限
recover 是 Go 语言中用于从 panic 中恢复程序正常执行的内建函数。它只能拦截显式的 panic 调用或某些严重的运行时错误(如数组越界、空指针解引用等),但无法处理普通的错误(error 类型)。
例如,以下情况 recover 无效:
函数返回 error,比如文件打开失败、JSON 解码错误 未触发 panic 的逻辑错误
必须配合 defer 使用
recover 只有在 defer 函数中调用才有意义。如果在普通代码流程中直接调用 recover,它会返回 nil。
立即学习“go语言免费学习笔记(深入)”;
青泥AI
青泥学术AI写作辅助平台
302 查看详情
示例:
func safeDivide(a, b int) (result int, ok bool) { defer func() { if r := recover(); r != nil { result = 0 ok = false } }() if b == 0 { panic("division by zero") } return a / b, true}
这个例子中,recover 成功捕获了 panic,程序不会崩溃。
无法捕获的场景
以下情况 recover 无能为力:
协程内部的 panic 不会传播到主协程,主协程的 defer/recover 捕获不到子协程的 panic 系统级崩溃,如内存耗尽、栈溢出(可能导致程序直接退出) 未被 defer 包裹的 panic
常见误解澄清
很多人误以为 recover 类似于其他语言的 try-catch,可以捕获所有异常。实际上 Go 的 error 和 panic 是两种不同的错误处理机制:
error 用于预期可能出错的情况,需主动检查和处理 panic 用于不可恢复的错误,应尽量避免滥用 recover 仅作为最后防线,防止程序整体崩溃
基本上就这些。recover 并非万能,合理使用 error 处理才是 Go 风格的核心。对可预见的错误,优先用 if err != nil 判断,而不是依赖 panic 和 recover。
以上就是Golang recover能否捕获所有错误的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1145812.html
微信扫一扫
支付宝扫一扫