错误处理实践指南:内置错误类型: 使用内置类型创建自定义错误。 error 接口: 使用%w语法包装错误以提供上下文。检查错误: 使用== nil检查错误是否存在。错误守卫: 简化错误处理过程。自定义类型: 创建自定义类型表示错误,提供更多信息。恢复: 使用recover()在发生恐慌时恢复函数。
Go 函数错误处理实践指南
引言
在Go 中正确处理错误至关重要,它可以显着提高应用程序的稳定性和可维护性。本文介绍了多种错误处理技术,并提供了实战案例以说明其用法。
1. 内置错误类型
Go提供了几个内置错误类型,如errors.New()
和fmt. Errorf("")
。我们可以使用这些类型创建自定义错误。
2. error
接口
error
接口允许不同的错误类型相互兼容。我们可以通过使用%w
语法来包装错误以提供上下文。
实战案例1:
import "errors" func OpenFile(fname string) error { f, err := os.Open(fname) if err != nil { return errors.New("failed to open file: " + err.Error()) } return nil }
3. 检查错误
我们可以使用== nil
检查错误。若为 nil
,则表示没有错误。
实战案例2:
func OpenFile(fname string) *os.File { f, err := os.Open(fname) if err != nil { return nil } return f }
4. 错误守卫
错误守卫语法(if err := f(); err != nil { ... }
)提供了一种简化的错误处理方式。
实战案例3:
func OpenFile(fname string) (*os.File, error) { if f, err := os.Open(fname); err != nil { return nil, err } else { return f, nil } }
5. 自定义类型
我们可以创建自定义类型来表示错误,并提供额外信息。
实战案例4:
type FileError struct { fname string err error } func (e FileError) Error() string { return fmt.Sprintf("failed to open file %s: %s", e.fname, e.err) } func OpenFile(fname string) (*os.File, error) { f, err := os.Open(fname) if err != nil { return nil, &FileError{fname, err} } return f, nil }
6. 恢复
使用recover()
可以在发生恐慌时恢复函数。
实战案例 5:
func OpenFile(fname string) *os.File { defer func() { if r := recover(); r != nil { fmt.Printf("recover: %s\n", r) } }() f, err := os.Open(fname) if err != nil { panic(err) } return f }
以上是golang函数错误处理实践指南的详细内容。更多信息请关注PHP中文网其他相关文章!