Pourquoi le retour normal masque la panique par rapport au retour nommé
Le scénario fourni démontre un comportement inattendu où NormalReturns() renvoie zéro malgré l'apparition d'un panique, tandis que NamedReturns() gère correctement la panique et fournit une erreur non nulle. Ce comportement découle de la nature des retours nommés dans Go.
Retours nommés
Si les valeurs de retour sont nommées, ce sont en fait des variables locales qui peuvent être modifiées dans la fonction. . L'instruction return est essentiellement une affectation à ces variables locales. En cas de panique, le runtime de Go permet aux fonctions différées de s'exécuter avant de terminer le programme. Ces fonctions différées peuvent accéder et modifier les variables de retour nommées.
Dans NamedReturns(), la fonction deferred catch() modifie la variable de résultat err pour définir un message d'erreur lorsqu'une panique se produit. Puisque cela se produit avant le retour de la fonction, la valeur d'erreur modifiée est renvoyée au lieu de nil.
Renvois normaux
D'autre part, dans NormalReturns(), le retour la valeur est initialisée à zéro et reste telle que car l'instruction return n'est pas atteinte avant la panique. La variable locale err, bien que sa valeur soit modifiée dans la fonction différée, n'a aucun impact sur la valeur de retour.
Distinction clé
Par conséquent, la distinction clé entre nommé Les rendements et les rendements normaux dans ce scénario résident dans leur capacité à modifier les valeurs de rendement en présence d'une panique. Les retours nommés permettent aux fonctions différées de mettre à jour ces valeurs, offrant ainsi plus de flexibilité dans la gestion des exceptions. Cependant, les retours normaux ne peuvent pas renvoyer des valeurs non nulles en raison de l'absence d'instruction return explicite avant l'apparition d'une panique.
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!