Maison > Article > développement back-end > Quelles sont les meilleures pratiques pour la gestion des erreurs dans le framework Golang ?
Bonnes pratiques : créez des erreurs personnalisées à l'aide de types d'erreurs bien définis (package d'erreurs) Fournissez plus de détails Enregistrez les erreurs de manière appropriée Propagez correctement les erreurs, évitez de masquer ou de supprimer les erreurs Wrap si nécessaire pour ajouter du contexte
Go Framework Meilleures pratiques de gestion des erreurs dans
La gestion des erreurs dans les applications Go est essentielle à l'écriture d'un code stable et robuste. La bibliothèque standard Go fournit une prise en charge intégrée de la gestion des erreurs, mais différents frameworks peuvent avoir leurs propres bonnes pratiques. Cet article décrit quelques directives pour une gestion optimale des erreurs lors de l'utilisation du framework Go.
1. Utiliser des types d'erreurs
Il est recommandé d'utiliser des types d'erreurs clairement définis, ce qui peut simplifier la gestion des erreurs et améliorer la lisibilité. Les types d'erreurs peuvent être créés via les fonctions New
ou Errorf
dans le package errors
. errors
包中的 New
或者 Errorf
函数创建。
例如:
import "errors" var ErrNotFound = errors.New("not found")
2. 使用自定义错误
在框架中编写自己的错误类型可以提供比内置错误类型更详细的信息。这允许应用程序以更有意义的方式处理错误。
例如:
type MyError struct { Message string } func (e MyError) Error() string { return e.Message }
3. 适当的日志记录
错误处理中一个重要的方面是日志记录。框架应该提供日志记录功能,以记录所有发生的错误。这有助于调试问题和跟踪应用程序行为。
例如,使用 log
包:
import "log" func main() { log.Fatal(ErrNotFound) }
4. 错误传播
函数应该正确传播错误,允许上层函数处理它们。避免隐藏或抑制错误,因为它会使调试变得困难。
func GetResource() (*Resource, error) { db, err := connectToDB() if err != nil { return nil, err } resource, err := db.GetResource() if err != nil { return nil, err } return resource, nil }
5. 错误包装
有时,需要增加对现有错误的上下文信息。错误包装(也称为错误累积)允许在原始错误之上添加额外的错误层。
import "fmt" func GetResource() (*Resource, error) { resource, err := db.GetResource() if err != nil { return nil, fmt.Errorf("failed to get resource: %w", err) } return resource, nil }
实战案例
考虑一个使用 Gin 框架构建的 REST API,该框架处理来自数据库的错误:
import ( "errors" "github.com/gin-gonic/gin" ) var ErrNotFound = errors.New("not found") func GetResource(c *gin.Context) { db, err := connectToDB() if err != nil { c.JSON(http.StatusInternalServerError, gin.H{"error": err.Error()}) return } resource, err := db.GetResource(c.Param("id")) if err == ErrNotFound { c.JSON(http.StatusNotFound, gin.H{"error": "resource not found"}) return } if err != nil { c.JSON(http.StatusInternalServerError, gin.H{"error": err.Error()}) return } c.JSON(http.StatusOK, resource) }
这个示例演示了:
ErrNotFound
log
: 🎜rrreee🎜🎜4. Propagation des erreurs 🎜🎜🎜Les fonctions doivent propager les erreurs correctement, permettant aux fonctions de couche supérieure de les gérer. Évitez de masquer ou de supprimer les erreurs car cela rend le débogage difficile. 🎜rrreee🎜🎜5. Error Wrapping🎜🎜🎜Parfois, il est nécessaire d'ajouter des informations contextuelles à une erreur existante. L'enveloppement d'erreurs (également appelé accumulation d'erreurs) permet d'ajouter des couches supplémentaires d'erreurs en plus de l'erreur d'origine. 🎜rrreee🎜🎜Exemple pratique🎜🎜🎜Considérons une API REST construite à l'aide du framework Gin qui gère les erreurs de la base de données : 🎜rrreee🎜Cet exemple démontre : 🎜ErrNotFound 🎜🎜Propage correctement les erreurs, les renvoyant au gestionnaire de réponse de Gin🎜🎜Renvoie le code d'état HTTP approprié en fonction du type d'erreur🎜🎜
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!