In RPC ist das Marshalling zu einem Schnittstellentyp unkompliziert, da das Objekt lokal ist und der Reflektor seinen zugrunde liegenden Typ identifizieren kann. Das Unmarshalling für einen Schnittstellentyp stellt jedoch eine Herausforderung dar.
Der Reflektor kann den konkreten Typ nicht bestimmen, der der neuen Instanz zugewiesen werden soll, die die gemarshallten Daten empfängt. Diese Einschränkung gilt für alle Marshalling-/Unmarshalling-Vorgänge.
Um dieses Problem in einigen Frameworks zu beheben, werden zusätzliche Informationen zur Unterstützung des Reflektors bereitgestellt. Beispielsweise gibt in Java Json(jackson) die JsonTypeInfo-Annotation den Klassentyp an.
In Go kann die Implementierung der Unmarshaler-Schnittstelle für Ihren benutzerdefinierten Typ diese Herausforderung bewältigen. Betrachten Sie das folgende Beispiel:
import ( "encoding/json" "errors" "fmt" "log" ) // RawString is a raw encoded JSON object. // It implements Marshaler and Unmarshaler and can // be used to delay JSON decoding or precompute a JSON encoding. type RawString string // MarshalJSON returns *m as the JSON encoding of m. func (m *RawString) MarshalJSON() ([]byte, error) { return []byte(*m), nil } // UnmarshalJSON sets *m to a copy of data. func (m *RawString) UnmarshalJSON(data []byte) error { if m == nil { return errors.New("RawString: UnmarshalJSON on nil pointer") } *m += RawString(data) return nil } const data = `{"i":3, "S":{"phone": {"sales": "2223334444"}}}` type A struct { I int64 S RawString `sql:"type:json"` } func main() { a := A{} err := json.Unmarshal([]byte(data), &a) if err != nil { log.Fatal("Unmarshal failed", err) } fmt.Println("Done", a) }
Das obige ist der detaillierte Inhalt vonWie kann ich JSON-Daten in einen Schnittstellentyp in Go entmarshalieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!