您好,登錄后才能下訂單哦!
json.Unmarshal 操作對象是一個 []byte,也就意味著被處理的JSON要全部加載到內存。
如果有一個加載完的JSON使用json.Unmarshal會快一些。
json.Decoder 操作的是一個stream,或者其他實現了io.Reader接口的類型。意味著可以在接收或傳輸的同時對其進行解析。當處理一組較大數據時無需重新copy整個JSON到內存中。
最好的選擇辦法如下:
如果數據來自一個io.Reader或者需要從一個stream中讀取數據,就選擇json.Decoder
如果已經將整個JSON加載到內存中了就使用json.Unmarshal
不定類型的解析
有時候遇到字段不定的JSON,需要一邊判斷一邊解析。如:
t1 := `{"type":"a", id:"aaa"}`t2 := `{"type":"b", id:22222}`
解組到interface{}
可以先統一解組到interface{} 然后判斷關鍵字段再進行后續處理。
type Data struct { Type string `json:"type"` Id interface{} `json:"id"`}func decode(t string) { var x Data err := json.Unmarshal([]byte(t), &x) if err != nil { panic(err) } if x.Type == "a" { fmt.Println(x.Id.(string)) } else { fmt.Println(x.Id.(float64)) //json解析中number默認作為float64解析 } }func main() { t1 := `{"type":"a", "id":"aaa"}` t2 := `{"type":"b", "id":22222}` decode(t1) decode(t2) }
結果
aaa 22222
以上就是golang不規則json解析的詳細內容,更多請關注億速云其它相關文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。