原文鏈接: http://www./post/17.html package main import ( "fmt" ) type NameEmtpyError struct { name string } //NameEmtpyError實(shí)現(xiàn)了 Error() 方法的對(duì)象都可以 func (e *NameEmtpyError) Error() string { return "name 不能為空" } func NameCheck(name string) (bool, error) { if name == "" { return false, &NameEmtpyError{name} // 注意error這里必須是地址&引用 } return true, nil } func main() { name := "" if check, err := NameCheck(name); err != nil { fmt.Println(err) } else { fmt.Println(check) } } 在go里定義錯(cuò)誤異常的方式有這么兩種,,但都需要你的返回值是error類(lèi)型的: 第二種方式是借用struct結(jié)構(gòu)體,創(chuàng)建一個(gè)struct的Error()方法,,注意這個(gè)方法名是Error,,不然會(huì)出現(xiàn)找不到Error方法。 package main import ( "errors" "fmt" ) type equalError struct { Num int } //方法名字是Error() func (e equalError) Error() string { return fmt.Sprintf("當(dāng)前數(shù)字是 %d ,大于10", e.Num) } //使用errors.New簡(jiǎn)單生成 func Equal(n int) (int, error) { if n > 10 { return -1, errors.New("大于10") //生成一個(gè)簡(jiǎn)單的 error 類(lèi)型 } return n, nil } func DiyEqual(n int) (int, error) { if n > 10 { return -1, equalError{Num: n} // 會(huì)調(diào)用equalError的Error方法 } return n, nil } func main() { //使用errors.New生成error對(duì)象 if result, err := Equal(20); err != nil { fmt.Println("錯(cuò)誤:", err) } else { fmt.Println("結(jié)果:", result) } //不適用erros,自定義錯(cuò)誤方式. if result, err := DiyEqual(20); err != nil { fmt.Println("錯(cuò)誤:", err) } else { fmt.Println("結(jié)果:", result) } } 當(dāng)然實(shí)際開(kāi)發(fā)項(xiàng)目也不建議這么寫(xiě),太lower不說(shuō),也不好擴(kuò)展. 下一篇準(zhǔn)備寫(xiě)個(gè)demo,封裝優(yōu)化錯(cuò)誤輸出的處理. |
|
來(lái)自: 新進(jìn)小設(shè)計(jì) > 《待分類(lèi)》