Feldsichtbarkeit in Go-Strukturen verstehen
Bei der Arbeit mit Strukturen in Go stoßen Entwickler häufig auf ein Problem, bei dem nur auf Felder mit großgeschriebenen Bezeichnern zugegriffen werden kann außerhalb des aktuellen Pakets. Dies kann besonders problematisch sein, wenn Strukturen in Datenbanken gespeichert oder an JSON weitergeleitet werden.
Im bereitgestellten Codeausschnitt enthalten die Strukturen „Person“ und „Sample“ Felder mit Bezeichnern in Groß- und Kleinschreibung. Bei der Interaktion mit der CouchDB-Datenbank oder der Konvertierung der Beispielstruktur in JSON werden jedoch nur die Felder mit großgeschriebenen Bezeichnern berücksichtigt.
Dieses Verhalten ist auf die Sichtbarkeitsregeln von Go zurückzuführen, die vorschreiben, dass nur Bezeichner, die mit Kleinbuchstaben beginnen, berücksichtigt werden innerhalb des aktuellen Pakets sichtbar. Da sich der JSON-Encoder und der CouchDB-Client in unterschiedlichen Paketen befinden, können sie nicht direkt auf Felder mit Kleinbuchstaben-Bezeichnern in der Struktur zugreifen.
Lösung: Verwendung von JSON-Tags
Zur Lösung Um diese Einschränkung zu umgehen, bietet Go einen Mechanismus namens „JSON-Tags“. Mit JSON-Tags können Sie angeben, wie Strukturfelder beim JSON-Marshalling und -Unmarshaling kodiert und dekodiert werden sollen. Durch Hinzufügen eines JSON-Tags zu einem Feld mit einer Kleinbuchstaben-ID können Sie es für den JSON-Encoder sichtbar machen.
Zum Beispiel:
type Sample struct { Name string `json:"name"` Age int `json:"age"` }
In diesem aktualisierten Code der Name und das Alter Felder sind beide mit der JSON-Direktive gekennzeichnet. Dies weist den JSON-Encoder an, beim Marshalling beide Felder einzubeziehen, auch wenn das Alter mit einem Kleinbuchstaben beginnt.
Erweitert auf CouchDB
Während dies bei der angegebenen Bibliothek für den CouchDB-Zugriff der Fall ist Obwohl JSON-Tags nicht explizit unterstützt werden, ist es möglich, die JSON-Kodierungsfunktion der Go-Standardbibliothek zu nutzen, um das gewünschte Ergebnis zu erzielen. Hier ist eine modifizierte Version der PostDocument-Funktion, die getaggte Felder verwendet:
func (db *Database) PostDocument(v interface{}) (*Document, error) { b, err := json.Marshal(v) if err != nil { return nil, err } resp, err := db.httpClient.Post(db.URL+db.name+"/", "application/json", bytes.NewReader(b)) if err != nil { return nil, err } defer resp.Body.Close() return decodeDocument(resp.Body) }
Durch die Verwendung der json.Marshal-Funktion zum Konvertieren der Struktur in JSON vor dem Posten in die Datenbank werden die getaggten Felder korrekt codiert.
Fazit
Die Feldsichtbarkeitsregeln und deren Nutzung von Go verstehen JSON-Tags sind von entscheidender Bedeutung, wenn Sie mit Strukturen über Paketgrenzen hinweg arbeiten. Durch die Anwendung dieser Prinzipien können Sie sicherstellen, dass alle Felder während des Datenaustauschs zugänglich und ordnungsgemäß serialisiert sind.
Das obige ist der detaillierte Inhalt vonWarum sind nur großgeschriebene Felder in Go-Strukturen außerhalb des Pakets zugänglich und wie kann ich kleingeschriebene Felder in JSON-Marshalling und Datenbankinteraktionen einbeziehen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!