proto 指定字段json名_Go学习_28_使用easyjson高效解析json数据

Golang自带的json包由于反射机制导致性能低下,适合配置文件解析。在高并发场景下,easyjson因其避免反射、提升解析性能而受到青睐。easyjson通过代码生成工具,根据结构体定义创建解析代码。通过测试,easyjson的运行时间和内存占用均优于内置json包。

Golang中自带的json包可以用来解析json数据,但是Golang自带的json解析是通过反射机制实现json数据的解析的,这样就造成了解析性能的底下,json包在解析本地配置文件的场景下使用的较多,但在一些高并发的场景下json就显得不足。

对于json的解析,我们可以使用easyjson包,避免使用反射,从而提高解析的性能,在众多Golang高性能解析json的框架中,easyjson名列前茅。使用easyjson首先需要安装easyjson:

go get -u github.com/mailru/easyjson/...

easyjson更多的资料在:

https://github.com/mailru/easyjson

easyjson在解析json数据的时候,并不是使用反射机制,而只针对预先定义好的json结构体对输入的json字符串进行纯字符串的截取,并将对应的json字段赋值给结构体。easyjson提供提供了代码生成工具,可以一键生成go文件中定义的结构体对应的解析代码:

easyjson -all ./json_data.go

上面的命令会将json_data.go中定义的所有Struct生成对应的json解析规则。

108aa714612530e7754baf63a1d31135.png

【注意】easyjson在解析json数据的时候虽然并不会使用反射机制,但是在使用easyjson生成解析代码的时候,easyjson还是会使用反射机制的,所以我们需要为每个解析字段指定FieldTag,否则easyjson就会将变量名当作解析字段生成解析代码,当然解析代码生成之后,easyjson解析json数据就和反射机制没有关系了。

生成的easyjson解析代码:

cc9a8c7264d6e8879db5f566b5f39e3f.png

使用easyjson解析json数据:

b777ff1b3820b92d9f31b5f8f18110b2.png

代码运行结果:

4159adab9859a7b452b7e76e8a634e24.png

之后我们使用Benchmark对Golang内置的json包以及eashjson包,解析相同的json数据并对解析好的Struct进行json转换,测试一下两者的性能:

编写json_test.go文件(Benchemark测试需要测试文件以_test结尾):

1d8c4cf828ad82f6023f894267a8bff3.png

运行Benchmark命令,测试代码性能:

go test -bench=. -benchmem

测试结果:

8de9c16bb2ae468fc16da568aa6d1fc6.png

从上面的测试结果可以看到,easyjson在测试中运行的时间大约是json包的三分之一,easyjson在单次运行占用内存和内存分配次数上也要比Golang内置的json包表现要好很多。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值