Décodage de flux JSON avec analyse basée sur les événements
Lorsque vous traitez des réponses JSON volumineuses contenant de grands tableaux, le décodage de l'intégralité de la réponse en mémoire peut consomment des ressources importantes et ont un impact sur les performances. Pour atténuer ce problème, nous pouvons utiliser l'analyse basée sur les événements avec json.Decoder pour diviser le flux JSON en morceaux plus petits et les traiter de manière incrémentielle.
Analyse basée sur les événements avec Decoder.Token()
Le json.Decoder fournit la méthode Token(), qui nous permet d'analyser uniquement le jeton suivant dans le flux JSON sans consommant la totalité de l'entrée. Cela nous permet d'analyser et de traiter le flux JSON de manière incrémentielle, objet par objet.
Traitement du flux JSON
Pour traiter le flux JSON, nous pouvons utiliser une machine à états qui suit la structure de l'objet JSON et gère les jetons en conséquence. Les étapes suivantes décrivent le processus :
Gestion des erreurs
La gestion des erreurs tout au long du processus est cruciale pour garantir une exécution correcte et cohérente. Une fonction de gestionnaire d'erreurs personnalisée peut simplifier la gestion des erreurs et fournir des messages d'erreur clairs.
Exemple de mise en œuvre
Voici un exemple de mise en œuvre basé sur le format JSON d'entrée fourni :
package main import ( "encoding/json" "fmt" "log" ) type LargeObject struct { Id string `json:"id"` Data string `json:"data"` } // Simplified error handling function func he(err error) { if err != nil { log.Fatal(err) } } func main() { // Example JSON stream jsonStream := `{ "somefield": "value", "otherfield": "othervalue", "items": [ { "id": "1", "data": "data1" }, { "id": "2", "data": "data2" }, { "id": "3", "data": "data3" }, { "id": "4", "data": "data4" } ] }` dec := json.NewDecoder(strings.NewReader(jsonStream)) // Read opening object t, err := dec.Token() he(err) if delim, ok := t.(json.Delim); !ok || delim != '{' { log.Fatal("Expected object") } // Read properties for dec.More() { t, err = dec.Token() he(err) prop := t.(string) if prop != "items" { var v interface{} he(dec.Decode(&v)) log.Printf("Property '%s' = %v", prop, v) continue } // Read "items" array t, err = dec.Token() he(err) if delim, ok := t.(json.Delim); !ok || delim != '[' { log.Fatal("Expected array") } // Read and process items for dec.More() { lo := LargeObject{} he(dec.Decode(&lo)) fmt.Printf("Item: %+v\n", lo) } // Read array closing t, err = dec.Token() he(err) if delim, ok := t.(json.Delim); !ok || delim != ']' { log.Fatal("Expected array closing") } } // Read closing object t, err = dec.Token() he(err) if delim, ok := t.(json.Delim); !ok || delim != '}' { log.Fatal("Expected object closing") } }
Notez que cette implémentation attend un objet JSON valide. La gestion des erreurs peut être étendue pour couvrir les entrées JSON mal formées ou incomplètes.
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!