Go 程序中的通用恐慌恢复
当 Go 程序中的并发例程遇到导致恐慌的严重错误时,优雅地恢复就变得至关重要处理这些异常并将其报告给外部报告服务(例如 Sentry 或 Raygun)。然而,从单独的 goroutine 中运行的例程中捕获恐慌是一个挑战。
Goroutine 恐慌问题
一个 goroutine 无法从另一个 Goroutine 中发生的恐慌中恢复。此限制在捕获和报告并发例程中的恐慌时带来了问题。
惯用恢复技术
要从并发例程中的恐慌中恢复,有必要将代码注入到goroutine 的函数,用于检查恢复的值。实现此目的的标准方法是使用调用recover()的延迟函数。
go func() { defer func() { if r := recover(); r != nil { fmt.Println("Caught:", r) } }() panic("catch me") }()
这种方法可确保 goroutine 中的任何恐慌都将被延迟函数捕获并相应记录。
用于简化恢复的包装函数
要简化恢复过程,您可以创建一个封装恢复逻辑的包装函数:
func wrap(f func()) { defer func() { if r := recover(); r != nil { fmt.Println("Caught:", r) } }() f() }
现在,您可以使用wrap()函数来保护任何goroutine函数免受恐慌:
go wrap(func() { panic("catch me") })
注意:wrapp() 函数允许您执行任意函数,而无需显式创建新的 goroutine,同时仍然确保恐慌恢复。
以上是如何优雅地处理和报告 Go 中 Goroutine 的恐慌?的详细内容。更多信息请关注PHP中文网其他相关文章!