Go中error是内置接口,通过返回值显式传递错误,需主动检查处理;任何实现Error() string的类型可作为error使用;函数出错时返回非nil error,应始终判断err是否为nil;可用errors.New或fmt.Errorf创建简单错误,也可自定义结构体实现更多上下文信息;支持与os.ErrNotExist等预定义错误比较,或通过errors.As进行类型提取;核心是养成检查、传播、记录或封装错误的良好习惯。

在Golang中,error 是一个内置的接口类型,用于表示错误状态。处理错误是Go语言编程中的核心实践之一。Go不使用异常机制,而是通过函数返回值显式地传递错误信息,开发者需要主动检查和处理这些错误。
error 是一个接口,定义如下:
type error interface {
Error() string
}任何实现了 Error() 方法(返回字符串)的类型都可以作为 error 使用。当函数执行出错时,通常会返回一个非 nil 的 error 值。
大多数函数在出错时会返回 error 作为最后一个返回值。你应该始终检查这个值。
立即学习“go语言免费学习笔记(深入)”;
示例:
file, err := os.Open("config.json")
if err != nil {
fmt.Println("打开文件失败:", err)
return
}
defer file.Close()在这个例子中,os.Open 返回两个值:文件句柄和一个 error。如果文件不存在或权限不足,err 就不是 nil,程序应进行相应处理。
你可以用 errors.New 或 fmt.Errorf 创建简单的错误:
if name == "" {
return errors.New("名称不能为空")
}或者带格式的错误:
return fmt.Errorf("解析失败: 不支持的类型 %T", value)如果需要更丰富的错误信息(如错误码、时间戳等),可以定义自己的错误类型:
type MyError struct {
When time.Time
What string
}
func (e *MyError) Error() string {
return fmt.Sprintf("%v: %s", e.When, e.What)
}
func problem() error {
return &MyError{
When: time.Now(),
What: "发生了一个问题",
}
}使用 == 可以判断 error 是否为 nil,也可以与预定义错误比较:
if err == os.ErrNotExist {
fmt.Println("文件不存在")
}对于自定义错误类型,可使用类型断言获取具体信息:
if e, ok := err.(*MyError); ok {
fmt.Printf("错误时间: %v, 内容: %s\n", e.When, e.What)
}也可使用 errors.As 更安全地提取特定类型的错误:
var myErr *MyError
if errors.As(err, &myErr) {
fmt.Println("自定义错误:", myErr.What)
}以上就是如何在Golang中使用error接口的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号