Go 错误处理实践总结示例
来源:脚本之家
时间:2023-01-07 11:55:59 291浏览 收藏
怎么入门Golang编程?需要学习哪些知识点?这是新手们刚接触编程时常见的问题;下面golang学习网就来给大家整理分享一些知识点,希望能够给初学者一些帮助。本篇文章就来介绍《Go 错误处理实践总结示例》,涉及到错误处理,有需要的可以收藏一下
Go 错误处理机制
Go 内置 errors
Go 语言中的 error
就是普通的一个接口,表示值
// http://golang.org/pkg/builtin/#error // error 接口的定义 type error interface { Error() string } // http://golang.org/pkg/errors/error.go // errors 构建 error 对象 type errorString struct { s string } func (e *errorString) Error() string { return e.s }
基础库中有大量自定义的 error
,如 Error: EOF
,而 errors.New()
返回的是内部 errorString
对象的指针。
Error 与 Exception
不同于 Java、C++ 等语言,Go 处理异常的逻辑是不引入 exception,而是采取多参数返回,因此可以在函数中带入 error interface 对象来交给调用者来进行处理。
func handle() (int, error) { return 1, nil } func main() { i, err := handle() if err != nil { return } // 其他处理逻辑 }
需要注意的是,Go 中有 panic 的机制,可以和 recovery 搭配实现类似于 try...exception...
的效果,但是 Go 中的 panic 并不等同于 exception,exception 一般是交由调用者来进行处理,而 Go panic 则是针对真正异常的情况(如索引越界、栈溢出、不可恢复的环境问题等),意味着代码不能继续运行,而不能假设调用者会来解决 panic。
Go 的多返回值来支持调用者进行错误处理的方式给予了开发者很大的灵活性,有如下优势
- 简单
- Plan for failure, not success
- 没有隐藏的控制流
- 完全交给开发者来控制 error
- error 是值,因此有很大的灵活性进行处理
Go 错误处理最佳实践
panic
panic 只用于真正异常的情况,如
- 在程序启动的时候,如果有强依赖的服务出现故障时 panic 退出
- 在程序启动的时候,如果发现有配置明显不符合要求, 可以 panic 退出(防御编程)
- 在程序入口处,例如 gin 中间件需要使用 recovery 预防 panic 程序退出
因为 panic 会导致程序直接退出,而如果使用 recovery 进行处理的话性能不好且不可控。因此,其他情况下只要不是不可恢复的程序错误,都不应该直接 panic 应该返回 error,从而交给开发者。
error
一般我们在开发中会使用 github.com/pkg/errors
处理应用错误,但需要注意的是,在公共库当中,我们一般不使用。
在通过多返回值来判断错误时,error
应该是函数的最后一个返回值,而当 error
不是 nil
时,其他返回值均应该为不可用状态,不应该对它们进行额外处理,错误处理的时候也应该先判断错误,当 if err != nil
时及时返回错误,从而避免过多的代码嵌套。
// 错误示例 func f() error { ans, err := someFunc() if err == nil { // 其他逻辑 } return err } // 正确示例 func f() error { ans, err := someFunc() if err != nil { return err } // 其他逻辑 return nil }
当程序出现错误时,一般使用 errors.New
或 errors.Errorf
返回错误值
func someFunc() error { res := anotherFunc() if res != true { errors.Errorf("结果错误,已尝试 %d 次", count) } // 其他逻辑 return nil }
而如果是调用其他函数出现问题,则应该直接返回,如果需要携带额外信息,则使用 errors.WithMessage
。
func someFunc() error { res, err := anotherFunc() if err != nil { return errors.WithMessage(err, "other information") } }
如果是调用其他库(标准库、企业公共库、开源第三方库等)获取到错误时,请使用 errors.Wrap
添加堆栈信息。只需要在错误第一次出现时使用,且在基础库和被大量引用的第三方库编写时一般不使用,避免堆栈信息重复。
func f() error { err := json.Unmashal(&a, data) if err != nil { return errors.Wrap(err, "other information") } // 其他逻辑 return nil }
当需要对错误进行判断时,需要采用 errors.Is
进行比较
func f() error { err := A() if errors.Is(err, io.EOF){ return nil } // 其他逻辑 return nil }
而对错误类型进行判断时则使用 errors.As
进行赋值
func f() error { err := A() var errA errorA if errors.As(err, &errA){ // ... } // 其他逻辑 return nil }
对于业务中的错误(如输入错误等),最好在统一的一个地方建立自己的错误字典,其中应该包含错误代码并且可以在日志中作为独立字段打印,也需要有清晰的文档。
我们常常用日志来辅助我们进行错误处理,不需要进行返回、被忽略的错误必须输出日志,但禁止每个出错的地方都打日志。而如果同一个地方不停地报错,最好是打印一次错误详情并打印出现次数。
总结
参考 golang gorm错误处理事务以及日志用法示例
更多关于Go 错误处理的资料请关注golang学习网其它相关文章!
今天关于《Go 错误处理实践总结示例》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于golang的内容请关注golang学习网公众号!
-
278 收藏
-
483 收藏
-
195 收藏
-
412 收藏
-
445 收藏
-
280 收藏
-
181 收藏
-
371 收藏
-
236 收藏
-
416 收藏
-
407 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习