Aller le traitement des erreurs
Aller langue fournit un mécanisme de gestion des erreurs très simple grâce à l'interface d'erreur intégré.
Type d'erreur est un type d'interface, qui est sa définition:
type error interface { Error() string }
Nous pouvons mettre en œuvre l'erreur type d'interface pour générer un message d'erreur dans le code.
Renvoie généralement un message d'erreur à la fin de la valeur de retour. Utilisez errors.New renvoie un message d'erreur:
func Sqrt(f float64) (float64, error) { if f < 0 { return 0, errors.New("math: square root of negative number") } // 实现 }
Dans l'exemple suivant, nous appelons le Sqrt lors du passage d'un nombre négatif, alors vous obtenez l'objet d'erreur est non-nulle, par rapport à cet objet nul, le résultat est vrai, alors fmt.Println (package fmt lors de la manipulation d'erreur l'erreur sera appelée méthode) est appelé à une erreur de sortie, voir appelle le code exemple suivant:
result, err:= Sqrt(-1) if err != nil { fmt.Println(err) }
Exemples
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) } }
Le programme ci-dessus, le résultat est:
100/10 = 10 errorMsg is: Cannot proceed, the divider is zero. dividee: 100 divider: 0