加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

Fastjson介绍

发布时间:2020-12-16 19:05:21 所属栏目:百科 来源:网络整理
导读:Fastjson介绍 Fastjson是一个Java语言编写的高性能功能完善的JSON库。由阿里巴巴 高性能 fastjson采用独创的算法,将parse的速度提升到极致,超过所有json库,包括曾经号称最快的jackson。并且还超越了google的二进制协议protocol buf。 支持标准 Fastjson完

Fastjson介绍

Fastjson是一个Java语言编写的高性能功能完善的JSON库。由阿里巴巴

高性能

fastjson采用独创的算法,将parse的速度提升到极致,超过所有json库,包括曾经号称最快的jackson。并且还超越了google的二进制协议protocol buf。

支持标准

  • Fastjson完全支持http://json.org的标准,也是官方网站收录的参考实现之一。

功能强大

  • 支持各种JDK类型。包括基本类型、JavaBean、Collection、Map、Enum、泛型等。

  • 支持循环引用

无依赖

  • 不需要例外额外的jar,能够直接跑在JDK上。

支持范围广

  • 支持JDK 5、JDK 6、Android、阿里云手机等环境。

开源

  • Apache License 2.0

  • 代码托管在github.org上,项目地址是https://github.com/AlibabaTech/fastjson

测试充分

  • fastjson有超过1500个testcase,每次构建都会跑一遍,丰富的测试场景保证了功能稳定。

下载

http://code.alibabatech.com/mvn/releases/com/alibaba/fastjson/


性能测试:

JavaJSON技术框架选型与实例

JSON

JSON英文全称为JavaScriptObject Natation,采用key:value键值对的方式存贮数据,与xml格式相比,JSON是一种轻量级的数据交换格式;不要被Javascript这个单词迷惑,实际上JSON只是一种数据格式,与具体语言并无关系。JSON已被广泛应用于业界,比如目前NoSQL数据库存贮大都采用key:value存贮结构,以Mongo为例,其脚本语法甚至直接使用Javascript;在数据传输时,采用JSON格式也被广泛应用,大部分开放API都开放JSON模式的数据输出;在ajax请求数据时,json格式也被广泛推荐。json更多信息的可以查看json官方网站http://json.org。

Java transient关键字

JAVA规范原文The transient marker is not fully specified by the Java LanguageSpecification but is used in object serialization to mark member variables thatshould not be serialized.为了方便存贮和网络传输,java有系列化对象机制,transient可用来指定当前不想被系列化的成员对象。举个例子说明transient的应用,在Mongo+Morphia开源项目下,如果对Java PO的成员指定transient,那么该成员数据将不会被存入Mongo数据库。另外一种应用场景就是这里要讲到的JSON,如果JAVA PO使用了Refrence(Mongo的Refrence)或者LazyLoading(可以理解成Hibernate LazyLoading概念),那么大部分的开源JAVA JSON相关项目,会自动加载这些Refrence、LazyLoading对象,如果PO形成相互引用,那就会形成死循环,即使没有形成死循环,大量不必要的数据被输出到客户端对资源的浪费也不容小觑。加上transient是一种解决办法。

基于JAVA的JSON主要开源项目及其对比

Json开源项目非常多,如org.json、JSON-Lib、jsontool、Jackson、Gson、SimpleJSON等等,后来专门查看了几种json开源测试数据对比后,决定采用fastjson。展示两组测试数据。首先来看大侠wangym(原博客http://wangym.iteye.com/blog/738933)对Jackson、JSON-Lib、Gson的测试结果

JSON转Bean,5个线程并发,约200字节对象,1千万次转换:

Jackson

JSON-lib

Gson

吞吐量

64113.7

8067.4

13952.8

总耗时(秒)

155

1238

700

Bean转JSON,5个线程并发,约200字节对象,1千万次转换:

Jackson

JSON-lib

Gson

吞吐量

54802

15093.2

17308.2

总耗时(秒)

181

661

560

显而易见,无论是哪种形式的转换,Jackson > Gson > Json-lib

Jackson的处理能力甚至高出Json-lib10倍左右

然后再拿温少的fastjson与JSON-Lib、Simple-JSON、Jackson性能测试对比数据

性能对比

测试案例

JSON-Lib

Simple-JSON

Fastjson

Jackson

IntArray1000Decode

3,626

1,431

563

596

StringArray1000Decode

2,698

677

774

Map100StringDecode

515

597

208

230

功能对比

特性

JSON-Lib

Simple-JSON

Fastjson

Jackson

序列化支持数组

不支持

支持

支持

序列化支持Enum

支持JavaBean

不直接支持

支持

可以看到Fastjson在性能方面,超越目前的所有java json proccesor,包括jackson


------------------------------------------------------------------------------------------------------

-----------------------------------------------------------------------------------------------------------

详细:fastjson 项目介绍

问题解决

背景:刚接触这个开源项目不久。遇到问题也不少。不过通过各方询问、及源码探究开源得到解决。最近使用FastJson结合hibernate做项目,发现关于对象的级联属性的过滤上用的不是很顺。当然简单的属性过滤@温少已经提供了 SimplePropertyPreFilter 使用,使用方法有详细说明的。这里我针对级联属性的过滤对该类做了补充。(当然你也可以使用注解实现)

ok、上代码:

测试代码:

ok ,代码已贴好,测试方法在 A类。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

相关内容
推荐文章
站长推荐
热点阅读