Maison >développement back-end >Golang >Comment gérer les valeurs nulles lors de l'analyse des données JSON int64 dans Go ?
Analyse JSON de int64 dans Go : gestion des valeurs nulles
Dans Go, l'analyse de données JSON contenant des valeurs entières de type int64 peut présenter des défis lorsque rencontrer des valeurs nulles. Lorsqu'il rencontre des valeurs nulles, le package JSON par défaut génère une erreur en raison de l'incapacité de transformer null en un int64.
Type int64 nullable pour l'analyse JSON
Pour surmonter ce problème limitation, un type int64 nullable est nécessaire. Un int64 nullable autorise soit une valeur nulle, soit une valeur int64 valide. En utilisant un pointeur dans Go, nous obtenons cette fonctionnalité :
type NullableInt64 *int64
Lors de l'utilisation d'un pointeur pour le type, il peut soit être nul, soit faire référence à une valeur int64.
Implémentation
Incorporation du type nullable int64 dans le précédent exemple :
package main import ( "encoding/json" "fmt" ) var d = []byte(`{ "world":[{"data": 2251799813685312}, {"data": null}]}`) type jsonobj struct{ World []World } type World struct{ Data *int64 } // Using *int64 for nullable int64 func main() { var data jsonobj jerr := json.Unmarshal(d, &data) fmt.Println(jerr) }
Cette modification permet à l'analyseur JSON de gérer avec succès les valeurs nulles dans le champ « données » sans rencontrer d'erreurs.
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!