golang常用库之pkg/errors包第三方错误处理包案例详解
作者:西京刀客 发布时间:2024-02-14 09:20:38
golang常用库之-pkg/errors包
背景
golang自带了错误信息包error
只提供了简单的用法, 如errors.New(),和errors.Error()用来传递和获取错误信息.
明显官方的包已经不能满足了, 只能采取其他方法补救, 如:采用三方errors包。
关于官方errors包
Go 语言使用 error 类型来返回函数执行过程中遇到的错误,如果返回的 error 值为 nil,则表示未遇到错误,否则 error 会返回一个字符串,用于说明遇到了什么错误。
查看golang的errors包你会发现其源码是:
package errors
// New returns an error that formats as the given text.
// Each call to New returns a distinct error value even if the text is identical.
func New(text string) error {
return &errorString{text}
}
// errorString is a trivial implementation of error.
type errorString struct {
s string
func (e *errorString) Error() string {
return e.s
New方法通过传入的text创建不同的errorString,这个结构体实现了Error()方法,这样便可以动态的创建不同的错误类型。
New返回了一个实现error
接口的errorString
类型的指针。 那为啥不是返回errorString的值类型??
我们在调用errors.New("")来返回一个错误时, **可以通过比较指针,来比较error是否相等, 实际上就是控制相同的错误我们只创建一个error对象。**否则对象复制一下,在比较就是false了。
而且指针才会与nil相比较, 如果是字符串"" 虽然错误内容为空,但是还是有错误的。
看过源码我们很清楚的知道内置的error类型包含的信息十分有限
官方errors包使用demo
package main
import (
"errors"
"fmt"
)
func main() {
err := errors.New("errors!!!!!!!!!!")
if err != nil {
fmt.Print(err)
}
}
什么是pkg/errors包
github.com/pkg/errors
Golang 的 error 不会像 Java 那样打印 stackTrack 信息。回溯 err 很是不方便。
pkg/errors 是一个用的比较多,同时也比较灵活的一个golang 异常处理包,我们基于此包,可以灵活的处理软件开发中的异常
位于github.com/pkg/errors 的errors包是Go标准库的替代品。它提供了一些非常有用的操作用于封装和处理错误。
经过 github.com/pkg/errors 这个包来处理 err,WithStack(err) 函数能够打印 stack
pkg/errors包使用demo
%s,%v //功能一样,输出错误信息,不包含堆栈
%q //输出的错误信息带引号,不包含堆栈
%+v //输出错误信息和堆栈
如:
fmt.Println(fmt.Sprintf("%s", err))
fmt.Println(fmt.Sprintf("%q", err))
fmt.Println(fmt.Sprintf("%+v", err))
注意,使用 log.Errorf("%+v", err) 才会打印 stackTrack,使用 %v %s 不行。
package main
import (
E "errors"
"fmt"
"github.com/pkg/errors"
)
func main() {
err0 := t1()
err := errors.Wrap(err0, "附加信息")
if err != nil {
//打印错误需要%+v才能详细输出
fmt.Printf("err :%+v\n", err)
}
fmt.Println("Hello world")
}
func t1() error {
return E.New("错误")
结果:
优秀开源项目使用案例
https://github.com/marmotedu/errors
作者基于 github.com/pkg/errors 包,增加对 error code 的支持,完全兼容 github.com/pkg/errors。
性能跟 github.com/pkg/errors 基本持平。
该 errors 包匹配的错误码设计请参考:marmotedu/sample-code
可以用于web服务 code message json返回效果。
如果返回结果中存在 code 字段,则表示调用 API 接口失败。例如:
{
"code": 100101,
"message": "Database error"
}
上述返回中 code 表示错误码,message 表示该错误的具体信息。每个错误同时也对应一个 HTTP 状态码,比如上述错误码对应了 HTTP 状态码 500(Internal Server Error)。
参考
Golang的错误处理
参考URL: https://zhuanlan.zhihu.com/p/89821850
来源:https://blog.csdn.net/inthat/article/details/123577248


猜你喜欢
- 我就废话不多说了,直接上代码吧!import cv2import osdef save_img(): video_path =
- 导入mybatis依赖<!--mybatis--><dependency> <groupId>
- 安装pygal,可参阅:pip和pygal的安装实例教程基本XY线:import pygalfrom math import cos&quo
- 需要注意的是:更改完源程序.c文件,需要对整个项目重新编译、make install,对已经生成的文件进行更新,类似于之前VS中在一个类中增
- 提要:系统自带的mysql默认字符集不是gbk,因此给数据库的推广应用以及中文程序的开发带来极大的不便,在没完没了的GBK和UTF8的转换过
- 背景介绍图片的全景拼接如今已不再稀奇,现在的智能摄像机和手机摄像头基本都带有图片自动全景拼接的功能,但是一般都会要求拍摄者保持设备的平稳以及
- Python 模块EasyGui详细介绍前言:在Windows想用Python开发一些简单的界面,所以找到了很容易上手的EasyGui库。下
- 九宫格是一种比较古老的设计,它最基本的表现其实就像是一个三行三列的表格。其实它最初是在window的c/s结构中用得比较多,比如我们经常看到
- 本文为大家分享了Windows下配置Python PyQt4开发环境的详细步骤,供大家参考,具体内容如下1. 下载相关软件Eclipse下载
- asp之家注:本篇asp留言本教程可以说是我见过的最详细,写的最认真的,最适合初学者来学习asp的一篇教程。在此感谢作者hemooday。可
- 解析url用的类库:python2版本: from urlparse import urlparseimport urllibpython3
- 查看MySQL执行的语句想实时查看MySQL所执行的sql语句,类似mssql里的事件探查器。对my.ini文件进行设置,打开文件进行修改:
- 在《Pragmatic ajax( * 站静态化) A Web 2.0 Primer 》中偶然看到对readyStae状态的介绍,感觉这个介
- 本教学使用环境介绍伺服器端:Ubuntu 18.04 LTS资料库:Mariadb 10.1.34(Mysql)语言版本:php 7.3本机
- 本文实例为大家分享了python使用Matplotlib绘制分段函数的具体代码,供大家参考,具体内容如下环境Python3Mac OS代码#
- “到底是什么将艺术和设计分开的?”这样一个话题听起来费解,长时间以来, 也已经被讨论过无数次。艺术家和设计师都是通过共通的知识和素养来创造视
- 学习python过程中想使用python的matlabplot绘图功能,遇到了一大批问题,然后一路过关斩将,最终安装成功,实为不易,发帖留念
- 在这系列视觉设计的文章间隙插一篇字体单位的文章。前文说了,字体单位应该用em而不用px,原因简单来说就是支持IE6下的字体缩放,在页面中按c
- HTML表单是网站交互性的经典方式。 本章将介绍如何用Django对用户提交的表单数据进行处理。一、HTTP 请求HTTP协议以"
- 网页给人最直观的感受就是它的页面框架与构造,就像一座大楼的主体框架与形态,你可能记不起东方明珠塔和艾菲尔铁塔是用什么颜色或什么材料涂的外墙,