ffjson-更快捷式JSON序列操作

  • 授权协议:Apache
  • 开发厂商:未知
  • 开发语言:go
  • 收录时间:2021-04-17
  • 操作系统:Windows,Linux,OS X
  • 软件作者:pquerna
  • 开源标签: ffjson

软件介绍

fjson 为 Go 结构产生 MarshalJSON 和 UnmarshalJSON 功能。

ffjson 为 Go 结构产生 MarshalJSON 和 UnmarshalJSON 功能。新生成的功能,减轻了进行序列化时对运行反射的依赖,速度比之前更快2至3倍。在 ffjson 不能识别涉及类型的情况下,它会回退到  encoding/json,这意味着 ffjson 是安全替代原件。通过使用 ffjson,您的 JSON 序列化只会越来越快,因为没有额外代码更改。

当你改变 struct 时,你需要重新运行 ffjson (或将它作为编译工具的一部分)。

入门:

如果 myfile.go 包含结构类型,你想要更快,假设 GOPATH 被设置为现有项目(这意味着在这个特殊的例子,如果 myfile.go 是在 MyProject 目录的一个合理值,该项应在$GOPATH/src/myproject),你可以运行:

go get -u github.com/pquerna/ffjsonffjson myfile.gogit add myfile_ffjson.go

性能:

  • MarshalJSON is 2x to 3x faster than encoding/json.

  • UnmarshalJSON is 2x to 3x faster than encoding/json.

特点:

  • 支持解组(Unmarshal Support):从 v0.9版本之后,开始支持散集结构。

  • 直接替代原件(Drop in Replacement):因 ffjson 执行的接口已被 encoding/json 定义,用户使用的性能增强。

  • 支持所有类型:ffjson 适用于大多数 Go 的类型——有任何类型路径不支持的话,他将自动会退到 encoding/json,这意味着所有的工作都要在 box 外工作,如果不是,打开一个issue 。

  • ffjson 跳跃:如果你想 ffjson 忽略一个结构,添加 ffjson ,跳过你想忽略的部分,然后重新串连。

  • 拓展测试:包含广泛的测试套件,适合与 JSON parser 相对的模糊测试。

上一篇:LPATHBench-最长路径计算的性能测试

下一篇:doctest-快速灵活的C++ 测试框架

相关阅读

查看更多 >