在 Go 开发中,错误日志记录是一个至关重要的问题。本文探讨了用于有效处理错误的几种标准技术。
创建固定错误变量(通常以“Err”前缀命名)是一种行之有效的方法。这些变量通常封装与特定错误条件一致的描述性字符串。示例:
var ( ErrSomethingBad = errors.New("some string") ErrKindFoo = errors.New("foo happened") )
错误类型,用“...Error”后缀表示,提供了一种更结构化的错误表示方式。它们包含带有可选字段或方法的自定义类型定义,以传达有关错误的附加信息。示例:
type SomeError struct { // extra information, whatever might be useful to callers // (or for making a nice message in `Error()`) ExtraInfo int } type OtherError string func (e SomeError) Error() string { /* … */ } func (e OtherError) Error() string { return fmt.Sprintf("failure doing something with %q", string(e)) }
使用错误。对于不需要进一步详细说明的通用错误情况,可以使用新方法生成临时错误值。示例:
func SomepackageFunction() error { return errors.New("not implemented") }
选择标准库中定义的适当错误(例如 io.EOF)在某些情况下可能很方便。尽管如此,为包中的特定错误条件创建自定义错误更为常见。示例:
func SomeFunc() error { return io.EOF }
Go 允许创建自定义错误接口,例如 net.Error,它使开发人员能够定义特定的行为和错误类别。示例:
type Error interface { error Timeout() bool // Is the error a timeout? Temporary() bool // Is the error temporary? }
在 Go 1.13 及更高版本中,错误包装允许使用附加上下文或详细信息扩展现有错误。这种方法有利于错误传播并有助于错误分析。示例:
func SomepackageFunction() error { err := somethingThatCanFail() if err != nil { return fmt.Errorf("some context: %w", err) } }
Go 中建立的错误类型允许对错误条件进行可靠的测试。开发人员可以将错误与预定义的变量进行比较,或者使用接口来检查特定的错误行为。示例:
err := somepkg.Function() if err == somepkg.ErrSomethingBad { // … } // or for an error type, something like: if e, ok := err.(somepkg.SomeError); ok && e.ExtraInfo > 42 { // use the fields/methods of `e` if needed }
在 Go 1.13 及更高版本中,errors.Is 和 error.As 函数通过有效地展开和匹配错误来提供增强的错误测试功能。
Go 提供了一套多功能的错误处理工具,允许开发人员根据自己的需求选择最合适的方法。通过利用本文中讨论的技术,您可以确保 Go 应用程序中强大的错误日志记录并提高代码质量。
以上是如何有效处理Go中的错误?的详细内容。更多信息请关注PHP中文网其他相关文章!