我目前正在构建一个小型库,用于同时读取/写入/移动文件。 在这样做的过程中,我遇到了错误处理的问题,这让我思考:
我想知道哪种方法最适合特定情况以及原因。
我建议阅读 Go 博客文章 Error Handling and Go 和 Effective Go on error,了解 Go 错误类型的威力。
一般来说,恐慌可以在库/包内使用,但它们不应该传播到包外,除非出现致命错误。换句话说,开发人员永远不必编写期望库出现恐慌的代码。
如果管理错误的传播很乏味,您可以在内部使用恐慌。在这种情况下,您可以使用传递错误的延迟/恢复处理程序来包装您的公共函数
func Function() (err error) {
defer func() {
if r := recover(); r != nil {
err = r.(error)
}
}()
// Do stuff
panic(errors.New("Error Message"))
}
此示例改编自标准库的
json
包,其中内部恐慌用于清理复杂的嵌套错误处理。