注意:
- 错误位置中的nil值表示没有错误
- if ae, ok := e.(*argError); ok {}
ae表示argError类型的值,ok表示是否有值。
“ * ”表示取值,这里要存在
第一种写法:
使用error.New创建error
func f1(arg int) (int, error) {
if arg == 42 {
//errors.New对给定的错误信息构造基础的错误值
return -1, errors.New("can't work with 42")
}
return arg + 3, nil
}
func main() {
for _, i := range []int{7, 42} {
if r, e := f1(i); e != nil {
fmt.Println("f1 failed:", e)
} else {
fmt.Println("f1 worked:", r)
}
}
}
其中 r 和 e 分别表示传出的int和error值
- 传入值为7时,if判断不执行,return 10,nil。e为nil,打印worked语句
- 传入值为42时,if判断执行, return -1,can’t work with 42。e不为nil,打印failed语句。
Output:
f1 worked: 10
f1 failed: can't work with 42
第二种写法:
使用一种自定义类型来表示错误
type argError struct {
arg int
prob string
}
func (e *argError) Error() string {
return fmt.Sprintf("%d - %s", e.arg, e.prob)
}
func f2(arg int) (int, error) {
if arg == 42 {
//这里使用&argError新建一个struct,对arg和prob赋值.
return -1, &argError{arg, "can't work with it"}
}
return arg + 3, nil
}
func main() {
for _, i := range []int{7, 42} {
if r, e := f2(i); e != nil {
fmt.Println("f2 failed:", e)
} else {
fmt.Println("f2 worked:", r)
}
}
//如果以编程方式使用自定义错误,可以使用断言进行定义类型
_, e := f2(42)
// e-得到的int和string的值(-1,can't work with it)
if ae, ok := e.(*argError); ok {
// ae即为一个argError类型的值。ok是一个bool类型,判断ae取值是否存在,如果存在执行if语句。
fmt.Println(ae.arg)
fmt.Println(ae.prob)
}
}
- 传入值为7时,if语句不执行,return 10,nil。e为nil,打印worked语句。
- 传入值为42,if语句执行,return -1,42-can’t work with it。e不为nil,打印failed语句。
Output:
f2 worked: 10
f2 failed: 42 - can't work with it
42
can't work with it