Golang est un langage de programmation de plus en plus populaire. Ses fonctionnalités sont simples et faciles à apprendre, et il prend en charge une concurrence élevée. Il est donc très populaire dans des domaines tels que le développement Web et le cloud computing. Cependant, la gestion des erreurs est une partie essentielle de l’écriture de programmes complexes. La méthode de gestion des erreurs de Golang est légèrement différente de celle des autres langages de programmation. Cet article présentera le mécanisme de gestion des erreurs dans Golang et fournira quelques techniques de gestion pratiques.
1. Mécanisme de gestion des erreurs
Dans Golang, l'erreur est un type intégré, qui a une implémentation simple, généralement une valeur de retour. Par conséquent, lorsqu’un appel de fonction échoue, il renvoie une erreur au lieu de lever une exception.
Voici un exemple de code basique qui renvoie une erreur :
func divide(a int, b int) (int, error) { if b == 0 { return 0, errors.New("division by zero") } return a/b, nil }
Dans le code ci-dessus, si la valeur de b est 0, la fonction renvoie une nouvelle erreur créée avec la fonction erreurs.New() et vérifie le retour à la fin. valeur du point d'appel.
Lorsque vous appelez une fonction qui renvoie une erreur, vous devez vérifier la valeur d'erreur renvoyée par la fonction, sinon le programme se terminera.
2. Pratique de gestion des erreurs
La façon de gérer les erreurs est une partie importante de l'écriture d'un logiciel de haute qualité. Voici quelques façons d'appliquer la gestion des erreurs :
func DoSomething() error { // 调用第三方API,返回一个错误 resp, err := http.Get("https://google.com") if err != nil { return fmt.Errorf("failed to get response: %w", err) // 透传错误 } // 处理响应 // … }
Dans le code ci-dessus, la fonction DoSomething() obtient la réponse en appelant la méthode http.Get(), et "transmet de manière transparente" l'erreur renvoyée par la méthode à la fonction supérieure. Cela signifie que la fonction DoSomething() ne gère pas les erreurs, elle renvoie indirectement une valeur d'erreur générée par http.Get(). Cela permet de localiser la cause première de l’erreur.
type MyError struct { ErrCode string Message string } func (e *MyError) Error() string { return fmt.Sprintf("[%s] %s", e.ErrCode, e.Message) } func DoSomething() error { err := &MyError{ ErrCode: "1000", Message: "something went wrong", } return err }
Dans le code ci-dessus, nous avons personnalisé un nouveau type MyError, qui implémente la méthode Error(). En définissant des codes d'erreur et des messages d'erreur spécifiques, vous pouvez décrire avec précision la cause de l'erreur.
var Log *log.Logger func init() { Log = log.New(os.Stdout, "MyApp: ", log.Ldate|log.Ltime|log.Lshortfile) } func DoSomething() error { // 处理错误 if err := DoMoreWork(); err != nil { Log.Println(fmt.Errorf("failed to do more work: %w", err)) return err } return nil }
Dans le code ci-dessus, nous utilisons la variable globale Log du package de journaux pour enregistrer les messages du journal. Lors du traitement des erreurs, connectez-vous à un fichier et renvoyez les erreurs. Cette approche élimine les comportements répétitifs de type journalisation entre les appels de fonction.
En bref, la gestion des erreurs est une tâche importante dans le développement d'applications Golang. Pour les programmeurs, soit la gestion des erreurs est bien effectuée, soit le programme peut ne pas fonctionner correctement. Par conséquent, les programmeurs Golang doivent comprendre et adopter des pratiques de gestion des erreurs telles que les erreurs transmises, les erreurs personnalisées et la gestion des erreurs au niveau du package pour garantir que leur code reste précis et efficace à tout moment.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!