Go 語言通過內(nèi)置的錯誤接口提供了非常簡單的錯誤處理機(jī)制。
error類型是一個接口類型,這是它的定義:
type error interface {
Error() string
}
我們可以在編碼中通過實(shí)現(xiàn) error 接口類型來生成錯誤信息。
函數(shù)通常在最后的返回值中返回錯誤信息。使用errors.New 可返回一個錯誤信息:
func Sqrt(f float64) (float64, error) {
if f < 0 {
return 0, errors.New("math: square root of negative number")
}
// 實(shí)現(xiàn)
}
在下面的例子中,我們在調(diào)用Sqrt的時候傳遞的一個負(fù)數(shù),然后就得到了non-nil的error對象,將此對象與nil比較,結(jié)果為true,所以fmt.Println(fmt包在處理error時會調(diào)用Error方法)被調(diào)用,以輸出錯誤,請看下面調(diào)用的示例代碼:
result, err:= Sqrt(-1)
if err != nil {
fmt.Println(err)
}
package main
import (
"fmt"
)
// 定義一個 DivideError 結(jié)構(gòu)
type DivideError struct {
dividee int
divider int
}
// 實(shí)現(xiàn) `error` 接口
func (de *DivideError) Error() string {
strFormat := `
Cannot proceed, the divider is zero.
dividee: %d
divider: 0
`
return fmt.Sprintf(strFormat, de.dividee)
}
// 定義 `int` 類型除法運(yùn)算的函數(shù)
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)
}
// 當(dāng)被除數(shù)為零的時候會返回錯誤信息
if _, errorMsg := Divide(100, 0); errorMsg != "" {
fmt.Println("errorMsg is: ", errorMsg)
}
}
執(zhí)行以上程序,輸出結(jié)果為:
100/10 = 10
errorMsg is:
Cannot proceed, the divider is zero.
dividee: 100
divider: 0
更多建議: