errors.As用于在错误链中查找指定类型错误并赋值,如自定义MyError类型可通过errors.As(err, &myErr)提取,需传入目标变量地址,适用于数据库约束、网络超时等场景。

在Go语言中,errors.As 是处理包装错误(wred errors)时非常实用的函数。它用于判断一个错误链中是否包含指定类型的错误,并将该错误赋值给目标变量。这在处理多层调用、中间可能包装了原始错误的场景下特别有用。
基本用法说明
errors.As 的签名是:
func As(err error, target interface{}) bool
如果 err 或其包装的任何底层错误可以转换为 target 指向的类型,As 返回 true,并把对应的错误赋值给 target。
自定义错误类型示例
下面是一个使用 errors.As 进行类型断言的完整示例:
立即学习“”;
package mn import ( “errors” “fmt” ) // 定义一个自定义错误类型 type MyError struct { Message string } func (e *MyError) Error() string { return e.Message } func function1() error { return &MyError{Message: “something went wrong”} } func function2() error { err := function1() return fmt.Errorf(“failed in function2: %w”, err) } func main() { err := function2() var myErr *MyError if errors.As(err, &myErr) { fmt.Printf(“Caught custom error: %sn”, myErr.Message) } else { fmt.Println(“Not a MyError type”) } }
输出结果:
一键出成片的录屏演示软件,专为制作产品演示、教学课程和使用教程而设计。
34 Caught custom error: something went wrong
关键点解析
上面的例子展示了如何跨越错误包装层级提取原始错误:
- function1 返回一个 *MyError 类型的错误
- function2 使用 %w 包装这个错误,形成错误链
- 在 main 中,通过 errors.As 判断整个错误链中是否存在 *MyError 类型
- 如果存在,就将该错误赋值给 myErr 变量
注意:传给 errors.As 的第二个参数必须是指向目标类型的指针的地址,即 &myErr,否则无法正确赋值。
常见使用场景
这种机制常用于:
- 判断是否是数据库唯一约束错误(如 PostgreSQL 的 unique_violation)
- 识别网络超时错误(比如 net.Error 接口中的 Timeout() 方法)
- 从中间件或框架封装的错误中提取原始业务错误
基本上就这些。只要记住 errors.As 是“在错误链中找匹配类型并赋值”的,就能正确使用它。不复杂但容易忽略细节。
以上就是Golang使用errors.As类型断言错误示例的详细内容,更多请关注php中文网其它相关文章!
微信扫一扫打赏
支付宝扫一扫打赏
