Go 语言通过内置的错误接口提供了非常简单的错误处理机制
error类型是一个接口类型,这是它的定义:
type error interface {Error() string}
我们可以在编码中通过实现 error 接口类型来生成错误信息
函数通常在最后的返回值中返回错误信息。使用errors.New 可返回一个错误信息
package mainimport ("fmt""errors")// type error interface {// Error() string// }// func Sqrt(f float64) (float64, error) {// if f < 0 {// return 0, errors.New("math: square root of negative number")// }else {// return 0, errors.New("math: square root of negative number")// }// }func Sqrt(f float64) (request float64, err error ) {if f < 0 {// request = 0err = errors.New("math: square root of negative number")return}else{return 0, errors.New("math: square root of negative number")}}func main() {request, err:= Sqrt(-1.0)if err != nil {fmt.Println(request,err)}}
在上面的例子中,我们在调用Sqrt的时候传递的一个负数,然后就得到了non-nil的error对象,将此对象与nil比较,结果为true,所以fmt.Println(fmt包在处理error时会调用Error方法)被调用,以输出错误
package mainimport ("fmt")// 定义一个 DivideError 结构type DivideError struct {dividee intdivider int}// 实现 `error` 接口func (de *DivideError) Error() string {strFormat := `Cannot proceed, the divider is zero.dividee: %ddivider: 0`return fmt.Sprintf(strFormat, de.dividee)}// 定义 `int` 类型除法运算的函数func Divide(varDividee int, varDivider int) (result int, errorMsg string) {if varDivider == 0 {dData := DivideError{dividee: varDividee,divider: varDivider,}errorMsg = dData.Error()return} else {return varDividee / varDivider, ""}}func main() {// 正常情况if result, errorMsg := Divide(100, 10); errorMsg == "" {fmt.Println("100/10 = ", result)}// 当除数为零的时候会返回错误信息if _, errorMsg := Divide(100, 0); errorMsg != "" {fmt.Println("errorMsg is: ", errorMsg)}}/*执行以上程序,输出结果为:100/10 = 10errorMsg is:Cannot proceed, the divider is zero.dividee: 100divider: 0*/
