上一篇 Go圣经-学习笔记之http.Handler接口git
下一篇 Go圣经-学习笔记之并发循环github
初学者通常使用error的方法:err:= errors.New("xxx"); fmt.Println(err.Error())
,咱们如今看一下error接口定义:golang
type error interface { Error() string }
Go语言默认实现了一个error接口,才有了初学者简单使用errors.New
函数并发
package errors func New(text string) { &errorString{text} } type errorString struct { text string } func (e *errorString) Error() string { return e.text }
正由于在errors标准库实现了一个默认的error接口,咱们就可使用默认的错误处理,返回错误信息。函数
这里要注意一点,有时候会犯错误,可能有些开发者会碰到下面这种状况。学习
func xxx(xxx, xxx) (retCode int, err error) if err == err1 { retCode = consts.DB__READ_ERROR } else if err == err2 { retCode = consts.DB__INSERT_ERROR } return
上面的返回结果有时候err不为空,可是retCode=0;有时候是正确的结果:err不为空,retCode也为0。.net
这是由于存在两种状况:日志
第一种方式,常常看到一些开发者这样作的:code
ErrTxHasBegan = errors.New("<Ormer.Begin> transaction already begin") ErrTxDone = errors.New("<Ormer.Commit/Rollback> transaction not begin") ErrMultiRows = errors.New("<QuerySeter> return multi rows") ErrNoRows = errors.New("<QuerySeter> no row found") ErrStmtClosed = errors.New("<QuerySeter> stmt already closed") ErrArgs = errors.New("<Ormer> args error may be empty") ErrNotImplement = errors.New("have not implement") // 预先定义好全部的业务逻辑错误,而后直接返回这些错误接口值的引用
第二种方式,比较low,直接是比较错误日志信息。orm
func xxx(xxx, xxx) (retCode int, err error) if err !=nil { if err.Error() == err1.Error() { retCode = consts.DB__READ_ERROR } else if err.Error() == err2.Error() { retCode = consts.DB__INSERT_ERROR } } return }
大多数开发者通常先定义业务逻辑错误接口值,而后引用这些错误值,就能够直接进行比较了。
注意一点, 接口值可不能够比较,主要看接口类型中的各个元素是否是能够比较的?就相似于struct能不能比较,就看struct的各个元素可不能够比较?
咱们通常比较少的直接使用errors.New, 它通常用于标准库内部Wrap使用。例如:
package fmt func Errorf(format string, a ...interface{}) error { return errors.New(fmt.Sprintf(format, a...)) } // 或者之前提过的一个github上的errors包:github.com/pkg/errors func Errorf(format string, args ...interface{}) error { return &fundamental{ msg: fmt.Sprintf(format, args...), stack: callers(), } }