Go中goroutine panic必须在内部用defer+recover捕获,recover仅在defer函数内有效;可预期错误应通过error channel传递,不可预期崩溃才用recover兜底并记录堆栈、清理后退出。
Go 中的 goroutine 一旦发生未捕获的 panic,会直接终止该协程,并且不会传播到主 goroutine,但若没做任何处理,panic 信息会打印到标准错误、程序可能看似“静默失败”,严重时还会引发资源泄漏或服务不可用。关键不是“能不能捕获”,而是必须在每个可能出错的 goroutine 内部主动设防。
这是应对未知崩溃(比如空指针、越界、向已关闭 channel 发送数据)的唯一可靠方式。recover 只在当前 goroutine 的 defer 函数中有效,离开 defer 就失效。
runtime.Stack 获取完整调用链对于可预期的错误(如网络超时、校验失败、数据库查不到),应避免 panic,改用 error 类型 + channel 回传。这是 Go 并发错误处理的推荐模式。
range 或 select 接收错误,配合 sync.WaitGroup 等待全部完成context.WithCancel,出错时调用 cancel()重复写 defer+recover 很繁琐,可以抽象成工具函数,让并发更健壮、更一致。
goSafe(func()),内部自动包裹 recover 日志逻辑
ger、trace ID、超时控制等上下文信息很多 goroutine 错误问题其实源于设计疏忽,而不是语法不会用。
基本上就这些。核心就两条:可预期的错走 error channel,不可预期的崩靠 defer+recover 守住底线。两者不冲突,常一起用。