错误处理实践指南:内置错误类型: 使用内置类型创建自定义错误。error 接口: 使用%w语法包装错误以提供上下文。检查错误: 使用== nil检查错误是否存在。错误守卫: 简化错误处理
错误处理实践指南:内置错误类型: 使用内置类型创建自定义错误。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
}
--结束END--
本文标题: golang函数错误处理实践指南
本文链接: https://www.lsjlt.com/news/612704.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
下载Word文档到电脑,方便收藏和打印~
2024-05-16
2024-05-16
2024-05-16
2024-05-16
2024-05-16
2024-05-16
2024-05-16
2024-05-16
2024-05-16
2024-05-16
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0