避免 Go 中重复的 Nil 错误检查
在 Go 中,常见的做法是在每个函数调用结束时检查错误,如下例所示:
a, err := doA() if err != nil { return nil, err } b, err := doB(a) if err != nil { return nil, err } c, err := doC(b) if err != nil { return nil, err }
虽然这种方法可以确保正确处理错误,但它可能会变得麻烦且重复,特别是如果错误检查代码占用的行数比实际逻辑多的话。
解决问题
有多种方法可以解决此问题:
1。拥抱重复
一些程序员认为重复并不是主要的不便,并且可以作为潜在错误处理路径的宝贵提醒。
2.错误检查的好处
与异常相比,Go 中的显式错误检查迫使开发人员预先考虑错误路径,确保资源管理得到适当处理。
3 。考虑恐慌/恢复
在某些情况下,恐慌和恢复可用于展开递归逻辑,但建议谨慎使用。
4.代码重组
重新组织代码结构有时可以减少重复错误检查的需要。
err := doA() if err != nil { return err } return doB()
5.命名结果(不鼓励)
使用命名结果从 return 语句中删除 err 变量可能会损害代码清晰度并产生潜在问题。
6. If Condition 之前的语句
Go if 语句接受条件之前的语句,允许内联错误检查:
if err := doA(); err != nil { return err }
以上是如何避免 Go 中繁琐的零错误检查?的详细内容。更多信息请关注PHP中文网其他相关文章!