Heim> System-Tutorial> LINUX> Hauptteil

Serialisierung und Deserialisierung von JSON-Daten

王林
Freigeben: 2024-01-09 11:30:17
nach vorne
4068 Leute haben es durchsucht
Einführung Der vollständige Name von json lautet Javascript-Objektnotation, und der vollständige chinesische Name lautet: js-Objektnotation. Zu den Serialisierungs- und Deserialisierungsprotokollen gehören: JSON, XML, YaML, Protokollpuffer usw. Unter diesen ist JSON die Hauptübertragungsform für Front-End- und Back-End-API-Vertragsdaten. json unterstützt vier Datentypen: numerische Werte, boolesche Werte, Arrays und Objekte. Mit diesen vier Datentypen können komplexe Datenmodelle erstellt werden.

In der Go-Sprache können wir die JSON-Standardbibliothek verwenden, um die Datenserialisierung und -deserialisierung zu implementieren. Diese Bibliothek bietet praktische Methoden zum Serialisieren und Deserialisieren von Karten, Strukturen, Arrays, Slices und integrierten primitiven Datentypen. Durch die Verwendung der JSON-Standardbibliothek können wir die Daten problemlos in das JSON-Format konvertieren und bei Bedarf wieder in den ursprünglichen Datentyp analysieren. Dies bietet uns einen hohen Komfort bei der Datenverarbeitung.

Hier werde ich drei Beispiele geben, um die Verwendung von JSON zu veranschaulichen. Für Anfänger kann es sein, dass Sie oft nur ein Strukturobjekt zum Empfangen und Senden von Daten verwenden. Schauen wir uns unten konkrete Beispiele an. 1. Verwenden Sie ein Strukturobjekt, um Daten zu empfangen: „ Typ Personenstruktur { Namenszeichenfolge „json:“name““. Alter int `json:"age"` } func main() { data := `{"name": "Alice", "age": 25}` var p Person err := json.Unmarshal([]byte(data), &p) if err != nil { fmt.Println("Fehler beim Parsen von JSON:", Fehler) zurückkehren

Serialisierung und Deserialisierung von JSON-Daten

Struktur

Typ Personenstruktur {
Namenszeichenfolge „json:"name"`
Alter int `json:"age"`
}


func main() {
var (
neuPro Person
bts []Byte
)
pro:=Person{
Name: „Lilie“,
Alter: 29,
}
// Serialisierung
if bts, err = json.Marshal(per); err !=nil{
log.Fatal(err.Error())
zurück
}


if err = json.Unmarshal(bts, &newPer); err !=nil{
log.Fatal(err.Error())
zurück
}
fmt.Println(newPer)
}

Karte

func main() {
var (
smap = map[string]int{
„Alter“: 28,
„Sex“: 1,
„Boden“: 12,
}
newSmap = make(map[string]int)
bts []Byte
)
if bts, err = json.Marshal(smap) err !=nil {
log.Fatal(err.Error())
zurück
}
if err = json.Umarshal(bts, &newSmap) err !=nil {
log.Fatal(err.Error())
zurück
}
fmt.Println(newSmap)
}

Dynamisches Array anordnen oder segmentieren

func main() {
var (
Alter []int = []int{23, 20, 28, 25, 30}
bts []Byte
äh fehler
newAges = make([]int, len(ages))
)
if bts, err = json.Marshal(ages); err != nil {
fmt.Println(err.Error())
zurück
}
if err = json.Unmarshal(bts, &newAges); err != nil {
fmt.Println(err.Error())
zurück
}
fmt.Println("new ages: ", newAges)
zurück
}

Anfänger sind sich der JSON-Serialisierung und Deserialisierung von Strukturen relativ bewusst, verwenden die beiden letzteren jedoch möglicherweise selten oder nie.

  • Für Daten vom Typ Array werden sie von einigen Frontends in Geschäftsszenarien verwendet.
  • Für den Kartentyp: Wenn die REST-Schnittstelle eines Drittanbieters auf dem Go-Sprachserver aufgerufen wird, benötigt der Server im Allgemeinen nur den angegebenen Rückgabecode, um festzustellen, ob der Aufruf erfolgreich ist. Der Programmierer wollte nicht die gesamte Strukturdefinition schreiben, oder vielleicht war er faul, also benutzte er ein Map[string]interface{}, um die Rückgabedaten zu empfangen. Zu diesem Zeitpunkt wird nach der Deserialisierung über Unmarshal in der JSON-Standardbibliothek der Rückgabecode über map["err_code"].(int) abgerufen und anschließend eine andere nachfolgende Verarbeitungslogik ausgeführt.

Hier möchte ich auch die Funktionen erklären, die ich manchmal verwende, wenn ich eine Struktur verwende, zum Beispiel die Tag-Wert-Funktion omitempty, die vom JSON der Struktur unterstützt wird:
Typ Personenstruktur {
Namenszeichenfolge „json:"name,omitempty"`
Alter int `json:"age"`
}
Das heißt, wenn der Tag-Wert der Funktion omitempty festgelegt ist und der Datenelementwert der entsprechenden Struktur Null ist, wird dieser nicht ausgegeben. Das heißt, wenn ein Element in den vom Server zurückgegebenen Strukturdaten leer ist und dieses Element nicht an das Frontend zurückgegeben wird, können Sie das JSON-Tag-Wertattribut omitempty verwenden.

Hier stellen wir Ihnen eine JSON-Parsing-Bibliothek zur Verfügung, die von Taowen, einem leitenden Ingenieur der Didi Company, geschrieben wurde und die schnellste der Welt ist. Github-Adresse: jsoniter.

Der Artikel wurde von der Open Source China Community [http://www.oschina.net] abgedruckt.

Das obige ist der detaillierte Inhalt vonSerialisierung und Deserialisierung von JSON-Daten. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:linuxprobe.com
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!