Latest web development tutorials

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