0

0

如何使用Golang自定义错误类型_定义结构体实现Error接口

P粉602998670

P粉602998670

发布时间:2025-12-24 13:07:53

|

404人浏览过

|

来源于php中文网

原创

Go中自定义错误最规范方式是定义结构体并实现Error()方法;可携带字段如Field、Code、Cause等,并支持错误链Unwrap,指针接收者避免拷贝且需返回可读字符串。

如何使用golang自定义错误类型_定义结构体实现error接口

在 Go 语言中,自定义错误类型最常用、最规范的方式是定义一个结构体,并让其实现 Error() 方法(即满足 error 接口)。这种方式比简单用 fmt.Errorf 更具表现力,能携带上下文、状态码、原始错误等信息,便于错误分类、日志记录和上层处理。

定义结构体并实现 error 接口

Go 的 error 接口非常简单:

type error interface {
  Error() string
}

只要结构体实现了 Error() string 方法,它就是合法的错误类型。例如:

type ValidationError struct {
  Field string
  Value interface{}
  Reason string
}

func (e *ValidationError) Error() string {
  return fmt.Sprintf("validation failed on field %q: %v (%s)", e.Field, e.Value, e.Reason)
}

注意:方法接收者建议用指针(*ValidationError),避免拷贝;同时确保返回有意义、可读的字符串。

立即学习go语言免费学习笔记(深入)”;

携带额外字段与错误链支持

真实项目中,错误往往需要携带更多信息,比如 HTTP 状态码、错误码、原始错误(cause)、时间戳等。还可以结合 Go 1.13+ 的错误链特性(Unwrap):

晓语台
晓语台

晓语台,是一款AI文本创作产品。创作能力主要围绕营销文本的AI创作,晓语台覆盖了品牌与市调、商业媒体、社交媒体、搜索营销、数字广告、职场办公共六类全营销文本

下载
type ApiError struct {
  Code int
  Message string
  Cause error
func (e *ApiError) Error() string {
  return fmt.Sprintf("API error %d: %s", e.Code, e.Message)
}

// 支持 errors.Is / errors.As 判断
func (e *ApiError) Unwrap() error { return e.Cause }

这样就能用 errors.Is(err, someTargetErr)errors.As(err, &target) 进行语义化错误匹配。

提供构造函数和快捷方法

避免直接 new 结构体,推荐封装构造函数,统一错误创建逻辑:

func NewValidationError(field string, value interface{}, reason string) error {
  return &ValidationError{Field: field, Value: value, Reason: reason}
}

func NewBadRequestError(msg string) error {
  return &ApiError{Code: 400, Message: msg}
}

还可为常用场景添加方法,如:

func (e *ApiError) IsClientError() bool { return e.Code >= 400 && e.Code func (e *ApiError) StatusCode() int { return e.Code }

在业务中使用与判断

抛出时直接返回自定义错误实例;捕获时可用类型断言或 errors.As 提取:

if err != nil {
  if ve, ok := err.(*ValidationError); ok {
    log.Printf("Validation error on %s: %v", ve.Field, ve.Value)
  } else if errors.Is(err, io.EOF) {
    // 处理标准错误
  }
}

更推荐用 errors.As,它能穿透错误包装链:

var ve *ValidationError
if errors.As(err, &ve) {
  log.Printf("Found validation error: %s", ve.Error())
}

相关专题

更多
golang如何定义变量
golang如何定义变量

golang定义变量的方法:1、声明变量并赋予初始值“var age int =值”;2、声明变量但不赋初始值“var age int”;3、使用短变量声明“age :=值”等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

173

2024.02.23

golang有哪些数据转换方法
golang有哪些数据转换方法

golang数据转换方法:1、类型转换操作符;2、类型断言;3、字符串和数字之间的转换;4、JSON序列化和反序列化;5、使用标准库进行数据转换;6、使用第三方库进行数据转换;7、自定义数据转换函数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

224

2024.02.23

golang常用库有哪些
golang常用库有哪些

golang常用库有:1、标准库;2、字符串处理库;3、网络库;4、加密库;5、压缩库;6、xml和json解析库;7、日期和时间库;8、数据库操作库;9、文件操作库;10、图像处理库。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

334

2024.02.23

golang和python的区别是什么
golang和python的区别是什么

golang和python的区别是:1、golang是一种编译型语言,而python是一种解释型语言;2、golang天生支持并发编程,而python对并发与并行的支持相对较弱等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

204

2024.03.05

golang是免费的吗
golang是免费的吗

golang是免费的。golang是google开发的一种静态强类型、编译型、并发型,并具有垃圾回收功能的开源编程语言,采用bsd开源协议。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

387

2024.05.21

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

193

2025.06.09

golang相关判断方法
golang相关判断方法

本专题整合了golang相关判断方法,想了解更详细的相关内容,请阅读下面的文章。

184

2025.06.10

golang数组使用方法
golang数组使用方法

本专题整合了golang数组用法,想了解更多的相关内容,请阅读专题下面的文章。

191

2025.06.17

苹果官网入口直接访问
苹果官网入口直接访问

苹果官网直接访问入口是https://www.apple.com/cn/,该页面具备0.8秒首屏渲染、HTTP/3与Brotli加速、WebP+AVIF双格式图片、免登录浏览全参数等特性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

10

2025.12.24

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Go 教程
Go 教程

共32课时 | 2.9万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号