FastJson---高性能JSON開發包

Fastjson介紹java

Fastjson是一個Java語言編寫的JSON處理器,由阿里巴巴公司開發。
一、遵循http://json.org標準,爲其官方網站收錄的參考實現之一。
二、功能qiang打,支持JDK的各類類型,包括基本的JavaBean、Collection、Map、Date、Enum、泛型。
三、無依賴,不須要例外額外的jar,可以直接跑在JDK上。
四、開源,使用Apache License 2.0協議開源。http://code.alibabatech.com/wiki/display/FastJSON/Home
五、具備超高的性能,java世界裏沒有其餘的json庫可以和fastjson可相比了。git

 

 

若是得到Fastjson?
SVN:http://code.alibabatech.com/svn/fastjson/trunk/
WIKI:http://code.alibabatech.com/wiki/display/FastJSON/Home
Issue Tracking:http://code.alibabatech.com/jira/browse/FASTJSONgithub

若是你使用了Maven,maven repository配置以下:web

<repository>
	<id>opensesame</id>
	<name>Alibaba OpenSource Repsoitory</name>
	<url>http://code.alibabatech.com/mvn/releases/</url>
	<snapshots>
		<enabled>false</enabled>
	</snapshots>
</repository>

pom.xml文件中加入依賴依賴:算法

<dependency>
	<groupId>com.alibaba</groupId>
	<artifactId>fastjson</artifactId>
	<version>1.0.4</version>
</dependency>

若是沒有使用maven,能夠直接下載:json

Binary : http://code.alibabatech.com/mvn/releases/com/alibaba/fastjson/1.1.1/fastjson-1.1.1.jar
Source :http://code.alibabatech.com/mvn/releases/com/alibaba/fastjson/1.1.1/fastjson-1.1.1-sources.jar
Subversion : http://code.alibabatech.com/svn/fastjson/緩存

使用介紹:
Fastjson的最主要的使用入口是com.alibaba.fastjson.JSONjvm

import com.alibaba.fastjson.JSON;

public static final Object parse(String text); // 把JSON文本parse爲JSONObject或者JSONArray
public static final JSONObject parseObject(String text); // 把JSON文本parse成JSONObject
public static final <T> T parseObject(String text, Class<T> clazz); // 把JSON文本parse爲JavaBean
public static final JSONArray parseArray(String text); // 把JSON文本parse成JSONArray
public static final <T> List<T> parseArray(String text, Class<T> clazz); //把JSON文本parse成JavaBean集合
public static final String toJSONString(Object object); // 將JavaBean序列化爲JSON文本
public static final String toJSONString(Object object, boolean prettyFormat); // 將JavaBean序列化爲帶格式的JSON文本
public static final Object toJSON(Object javaObject); 將JavaBean轉換爲JSONObject或者JSONArray。

代碼示例:
代碼示例用到類User和Group:maven

public class User {
	private Long id;
	private String name;

	public Long getId() { return id; }
	public void setId(Long id) { this.id = id; }

	public String getName() { return name; }
	public void setName(String name) { this.name = name; }
}
public class Group {
	private Long id;
	private String name;
	private List<User> users = new ArrayList<User>();

	public Long getId() { return id; }
	public void setId(Long id) { this.id = id; }

	public String getName() { return name; }
	public void setName(String name) { this.name = name; }

	public List<User> getUsers() { return users; }
	public void setUsers(List<User> users) { this.users = users; }
}

Encode代碼示例:svn

import com.alibaba.fastjson.JSON;

Group group = new Group();
group.setId(0L);
group.setName("admin");

User guestUser = new User();
guestUser.setId(2L);
guestUser.setName("guest");

User rootUser = new User();
rootUser.setId(3L);
rootUser.setName("root");

group.getUsers().add(guestUser);
group.getUsers().add(rootUser);

String jsonString = JSON.toJSONString(group);

System.out.println(jsonString);

 

Decode 代碼示例:

Group group2 = JSON.parseObject(jsonString, Group.class);

以前的一個版本是1.1.0,1.1.0採用asm和SortFastMatch算法提升性能,因爲過於着急展現其優越的性能,沒有進行嚴格測試就發佈了。

1.1.1相對於1.1.0,這是一個比較穩定的版本了,行測試覆蓋率從新提高到90%以上,build verify testcase 983個。

這個版本進一步完善了asm和SortFieldFastMatch算法,進一步提高了性能,同時補充了大量的testcase,提高了穩定性,我向你推薦使用這個版本,使用這個版本你將會獲得使人驚奇的性能。

1.1.1版本的asm來源自objectweb的asm項目,根據fastjson的須要作裁剪,確保引入asm的同時不引發包大小的過渡變大。

爲了更好使用sort field martch優化算法提高parser的性能,fastjson序列化的時候,缺省把SerializerFeature.SortField特性打開了。反序列化的時候也缺省把SortFeidFastMatch的選項打開了。這樣,若是你用fastjson序列化的文本,輸出的結果是按照fieldName排序輸出的,parser時也能利用這個順序進行優化讀取。這種狀況下,parser可以得到很是好的性能。

我使用github.com/eishay/jvm-serializers/提供的程序作測試,性能數據以下:

  序列化時間 反序列化時間 大小 壓縮後大小
java序列化 8546 43199 889 541
hessian 6643 10043 501 313
protobuf 3008 1694 239 149
thrift 3182 1951 349 197
avro 3575 2095 221 133
json-lib 45734 149741 485 263
jackson 3245 2986 503 271
fastjson 2292 1499 468 251

測試跑的腳本是:

./run -chart -include=`cat serializers.txt | tr "\\n" ","`  data/media.1.cks

從上面的數據來看,fastjson的性能已經超越protobuf、thrift、avro這些二進制協議了。一個文本協議的性能超越二進制協議是很難的,我很高興向你們宣佈我作到了!!

鑑於fastjson優越的性能表現,我建議作以下事情;
一、替換其餘全部的json庫,java世界裏沒有其餘的json庫可以和fastjson可相比了。
二、使用fastjson的序列化和反序列化替換Java serialize,java serialize不單性能慢,並且體制大。
三、使用fastjson替換hessian,json協議沒必要hessian體積大,並且fastjson性能優越,數倍於hessian
四、把fastjson用於memached緩存對象數據。

How to get it?

If you're Maven user, just use our maven repository(http://code.alibabatech.com/mvn/releases/) with folloging dependency

<dependency>
     <groupId>com.alibaba</groupId>
     <artifactId>fastjson</artifactId>
     <version>1.1.1</version>
</dependency>

Downlaods

Binary : http://code.alibabatech.com/mvn/releases/com/alibaba/fastjson/1.1.1/fastjson-1.1.1.jar
Source :http://code.alibabatech.com/mvn/releases/com/alibaba/fastjson/1.1.1/fastjson-1.1.1-sources.jar
Subversion : http://code.alibabatech.com/svn/fastjson/

相關文章
相關標籤/搜索