エラー処理を行きます2024 年の最新の入門チュートリアル。このコースでは エラー処理を行きます について学習できます。
言語は組み込みのエラーインタフェースを介して、非常に単純なエラー処理メカニズムを提供しに行きます。
エラーの種類は、その定義であるインターフェイスタイプ、次のとおりです。
type error interface { Error() string }
私たちは、コード内のエラーメッセージを生成するために、エラー・インタフェース・タイプを実装することができます。
この関数は、一般的に、戻り値の最後にエラーメッセージを返します。 使用errors.Newはエラーメッセージを返します。
func Sqrt(f float64) (float64, error) { if f < 0 { return 0, errors.New("math: square root of negative number") } // 实现 }
次の例では、負の数を渡すとき、あなたはエラーオブジェクトを取得するのSqrtを呼び出し、このオブジェクトはnilと比較して、非nilでfmt.Println(FMTパッケージのエラーを処理するときので、その結果は、真でありますエラーメソッドが呼び出されます)は、次のサンプルコードの呼び出しを参照して、出力誤差に呼び出されます。
result, err:= Sqrt(-1) if err != nil { fmt.Println(err) }
package main import ( "fmt" ) // 定义一个 DivideError 结构 type DivideError struct { dividee int divider int } // 实现 `error` 接口 func (de *DivideError) Error() string { strFormat := ` Cannot proceed, the divider is zero. dividee: %d divider: 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 = 10 errorMsg is: Cannot proceed, the divider is zero. dividee: 100 divider: 0