這篇文章主要介紹“go json解析器的原理是什么”,在日常操作中,相信很多人在go json解析器的原理是什么問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”go json解析器的原理是什么”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
成都創(chuàng)新互聯(lián)專業(yè)為企業(yè)提供新源網(wǎng)站建設、新源做網(wǎng)站、新源網(wǎng)站設計、新源網(wǎng)站制作等企業(yè)網(wǎng)站建設、網(wǎng)頁設計與制作、新源企業(yè)網(wǎng)站模板建站服務,10余年新源做網(wǎng)站經(jīng)驗,不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡服務。
當寫個小demo或者做個小工具,沒有大規(guī)模使用場景,那使用哪個庫都是一樣的,因為性能的體現(xiàn)并不會很明顯。但是如果是在實際項目中使用,且伴隨著高并發(fā),大容量等場景,我還是推薦使用json-iterator
。
"encoding/json" 官當自帶
號稱最快的go json解析器。跟官方的寫法兼容,我目前基本都使用這個。
效率對比
ns 納秒 op 操作
ns/op | allocation bytes | allocation times | |
---|---|---|---|
std decode | 35510 ns/op | 1960 B/op | 99 allocs/op |
easyjson decode | 8499 ns/op | 160 B/op | 4 allocs/op |
jsoniter decode | 5623 ns/op | 160 B/op | 3 allocs/op |
std encode | 2213 ns/op | 712 B/op | 5 allocs/op |
easyjson encode | 883 ns/op | 576 B/op | 3 allocs/op |
jsoniter encode | 837 ns/op | 384 B/op | 4 allocs/op |
type Hero struct { Name string Age int Birthday string Sal float64 Skill string }
hero := Hero{ Name: "小王", Age: 20, Birthday: "2021-02-23", Sal: 88.02, Skill: "技能", } jsonStu, err := json.Marshal if err != nil { fmt.Println("生成json字 } fmt.Println(string(jsonStu))
str := "{\"Name\":\"張三豐\",\"Age\":98,\"Birthday\":\"2001-09-21\",\"Sal\":3800.85,\"Skill\":\"武當劍法\"}" var hero Hero err := json.Unmarshal([]byte(str), &hero) if err != nil { fmt.Printf("unmarshal err=%v\n", err) }
倆種方式,一種直接反序列化成 結構體數(shù)組,另一種反序列化為 slice,內(nèi)容為map[string]interface{}
結構體數(shù)組
str := `[{"Name":"張三豐","Age":98,"Birthday":"2001-09-21","Sal":3800.85,"Skill":"武當劍法"},{"Name":"張無忌","Age":28,"Birthday":"2004-09-21","Sal":300.85,"Skill":"乾坤大挪移"}]` var hero []Hero err := json.Unmarshal([]byte(str), &hero) if err != nil { fmt.Printf("unmarshal err=%v\n", err) } fmt.Printf("反序列化后 hero=%v", hero)
slice
str := `[{"Name":"張三豐","Age":98,"Birthday":"2001-09-21","Sal":3800.85,"Skill":"武當劍法"},{"Name":"張無忌","Age":28,"Birthday":"2004-09-21","Sal":300.85,"Skill":"乾坤大挪移"}]` //定義一個slice var slice []map[string]interface{} //注意:反序列化map,不需要make,因為make操作被封裝到Unmarshal函數(shù) err := json.Unmarshal([]byte(str), &slice) if err != nil { fmt.Printf("unmarshal err=%v\n", err) } fmt.Printf("反序列化后 slice=%v\n", slice)
到此,關于“go json解析器的原理是什么”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續(xù)學習更多相關知識,請繼續(xù)關注創(chuàng)新互聯(lián)網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>
分享名稱:gojson解析器的原理是什么
標題路徑:http://weahome.cn/article/jegcjc.html