JSON.simple VS GSON VS Jackson VS JSONP
![]() 高吞吐量的情况下,会频繁地传输并解析小文件,因此一开始的时候可能性能的差距并不明显。但如果你需要在非常高负载下频繁地解析大量的小文件,差距就开始增大了。微服务及分布式架构经常会使用 JSON 来传输此类文件,因为这已经是 WEB API 的事实标准。 不是所有的 JSON 库都叫” 特仑苏”。如何根据使用场景才选择正确的库是相当重要的。希望这个基准测试能够对你有所帮助。 JSON 库 JSON.simple vs GSON vs Jackson vs JSONP 我们选择了四个主流的 JSON 库来进行基准测试:JSON.simple, GSON, Jackson 以及 JSONP。在 Java 中进行 JSON 解析通常都会用到这几个库,选择它们的原因是它们在 Github 项目中的亮相频率很高。 下面便是我们所测试的 JSON 库:
基准测试 我们同时使用大文件和小文件对这些库进行了基准测试。随着文件大小的不同,处理这些文本所需要的系统资源也会随之上升。 这个基准测试主要关注两个关键场景:大文件下 (190MB) 的解析速度与小文件(1KB)下的解析速度。大文件取自这里。小文件是从这里随机生成的。 不管是大文件还是小文件,我们都会用同一个库重复运行 10 次。对于每一个大文件,我们都会用同一个库来分别运行 10 次。而对于小文件,在单个库的单次运行中会重复执行 10000 次。在小文件测试的各次迭代中,文件内容都不会驻留在内存里,测试所运行的机器是 AWS 的 c3.large 实例。 大文件的完整测试结果如下,我对小文件的结果求了个平均值。 高吞吐量的情况下,会频繁地传输并解析小文件,因此一开始的时候可能性能的差距并不明显。但如果你需要在非常高负载下频繁地解析大量的小文件,差距就开始增大了。微服务及分布式架构经常会使用 JSON 来传输此类文件,因为这已经是 WEB API 的事实标准。 不是所有的 JSON 库都叫” 特仑苏”。如何根据使用场景才选择正确的库是相当重要的。希望这个基准测试能够对你有所帮助。 JSON 库 JSON.simple vs GSON vs Jackson vs JSONP 我们选择了四个主流的 JSON 库来进行基准测试:JSON.simple, GSON, Jackson 以及 JSONP。在 Java 中进行 JSON 解析通常都会用到这几个库,选择它们的原因是它们在 Github 项目中的亮相频率很高。 下面便是我们所测试的 JSON 库:
基准测试 我们同时使用大文件和小文件对这些库进行了基准测试。随着文件大小的不同,处理这些文本所需要的系统资源也会随之上升。 这个基准测试主要关注两个关键场景:大文件下 (190MB) 的解析速度与小文件(1KB)下的解析速度。大文件取自这里。小文件是从这里随机生成的。 不管是大文件还是小文件,我们都会用同一个库重复运行 10 次。对于每一个大文件,我们都会用同一个库来分别运行 10 次。而对于小文件,在单个库的单次运行中会重复执行 10000 次。在小文件测试的各次迭代中,文件内容都不会驻留在内存里,测试所运行的机器是 AWS 的 c3.large 实例。 大文件的完整测试结果如下,我对小文件的结果求了个平均值。 (编辑:泉州站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |