写点什么

Golang 号称最快的 Json 解析器速度可达 5623ns/op

用户头像
happlyfox
关注
发布于: 2021 年 03 月 25 日

关于我


作者博客|文章首发


golang 对 json 序列化和反序列化的操作实在是难受,所以说用习惯了高级语言特性,再转到这些偏原生的写法上就会很难受。


不多 BB,开始记录。


序列化库的选择


当写个小 demo 或者做个小工具,没有大规模使用场景,那使用哪个库都是一样的,因为性能的体现并不会很明显。但是如果是在实际项目中使用,且伴随着高并发,大容量等场景,我还是推荐使用json-iterator


go 自带 json 库


"encoding/json" 官当自带
复制代码


json-iterator

号称最快的 go json 解析器。跟官方的写法兼容,我目前基本都使用这个。


https://github.com/json-iterator/go


效率对比


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.Marshalif err != nil {	fmt.Println("生成json字}fmt.Println(string(jsonStu))
复制代码


反序列化


结构体 struct


str := "{\"Name\":\"张三丰\",\"Age\":98,\"Birthday\":\"2001-09-21\",\"Sal\":3800.85,\"Skill\":\"武当剑法\"}"var hero Heroerr := json.Unmarshal([]byte(str), &hero)if err != nil {fmt.Printf("unmarshal err=%v\n", err)}
复制代码


结构体数组


俩种方式,一种直接反序列化成 结构体数组,另一种反序列化为 slice,内容为 map[string]interface{}


结构体数组


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 []Heroerr := 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":"乾坤大挪移"}]`
//定义一个slicevar slice []map[string]interface{}//注意:反序列化map,不需要make,因为make操作被封装到Unmarshal函数err := json.Unmarshal([]byte(str), &slice)if err != nil {fmt.Printf("unmarshal err=%v\n", err)}fmt.Printf("反序列化后 slice=%v\n", slice)
复制代码


推荐阅读


Redis工具收费后新的开源已出现


GitHub上Star最高的工程师技能图谱


中国程序员最容易发错的单词


END


欢迎关注公众号 程序员工具集 👍👍 致力于分享优秀的开源项目、学习资源 、常用工具


回复关键词“关注礼包”,送你一份最全的程序员技能图谱。


回复关键词"wx"添加个人微信,勾搭作者,欢迎来聊^-^。


发布于: 2021 年 03 月 25 日阅读数: 14
用户头像

happlyfox

关注

公众号 程序员工具集 2021.02.18 加入

博客 [www.zhouhuibo.club] 分享优秀的开源项目、学习资源和常用工具。谈论新闻热点、职场经验、学习感悟。共同进步!

评论

发布
暂无评论
Golang号称最快的Json解析器速度可达5623ns/op