Lors de l'utilisation de la fonction json.Marshal dans Go, il est crucial de prendre en compte les données d'entrée qui peuvent déclencher une erreur. Comme mentionné dans la documentation officielle, les structures de données cycliques ne sont pas prises en charge et tenter de les rassembler conduit à une récursivité infinie, entraînant finalement une panique d'exécution.
Pour démontrer une condition d'erreur non-panique, créons un programme qui présente deux types d'erreurs que json.Marshal peut renvoyer : UnsupportedTypeError et UnsupportedValueError.
<code class="go">package main import ( "encoding/json" "fmt" "math" ) func main() { // UnsupportedTypeError: marshalling an invalid type (channel) ch := make(chan int) _, err := json.Marshal(ch) if e, ok := err.(*json.UnsupportedTypeError); ok { // Check for specific error type fmt.Println("UnsupportedTypeError:", e.Type) } else { fmt.Println("Error:", err) } // UnsupportedValueError: marshalling an invalid value (infinity) inf := math.Inf(1) _, err = json.Marshal(inf) if e, ok := err.(*json.UnsupportedValueError); ok { // Check for specific error type fmt.Println("UnsupportedValueError:", e.Value) } else { fmt.Println("Error:", err) } }</code>
Sortie :
UnsupportedTypeError: chan int UnsupportedValueError: +Inf
En fournissant des entrées spécifiques, ce programme démontre que json.Marshal peut renvoyer erreurs non nulles sans provoquer de panique. Cela permet aux développeurs de gérer ces erreurs avec élégance dans leurs applications.
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!