溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

高性能JSON開發(fā)包FastJson怎么用

發(fā)布時間:2021-12-13 19:19:02 來源:億速云 閱讀:174 作者:柒染 欄目:云計算

高性能JSON開發(fā)包FastJson怎么用,針對這個問題,這篇文章詳細(xì)介紹了相對應(yīng)的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

Fastjson介紹

Fastjson是一個Java語言編寫的JSON處理器,由阿里巴巴公司開發(fā)。
1、遵循h(huán)ttp://json.org標(biāo)準(zhǔn),為其官方網(wǎng)站收錄的參考實現(xiàn)之一。
2、功能qiang打,支持JDK的各種類型,包括基本的JavaBean、Collection、Map、Date、Enum、泛型。
3、無依賴,不需要例外額外的jar,能夠直接跑在JDK上。
4、開源,使用Apache License 2.0協(xié)議開源。http://code.alibabatech.com/wiki/display/FastJSON/Home
5、具有超高的性能,java世界里沒有其他的json庫能夠和fastjson可相比了。

如果獲得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/FASTJSON

如果你使用了Maven,maven repository配置如下:

<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,可以直接下載:

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.JSON

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轉(zhuǎn)換為JSONObject或者JSONArray。

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

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代碼示例:

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算法提高性能,由于過于著急展示其優(yōu)越的性能,沒有進(jìn)行嚴(yán)格測試就發(fā)布了。

1.1.1相對于1.1.0,這是一個比較穩(wěn)定的版本了,行測試覆蓋率重新提升到90%以上,build verify testcase 983個。

這個版本進(jìn)一步完善了asm和SortFieldFastMatch算法,進(jìn)一步提升了性能,同時補(bǔ)充了大量的testcase,提升了穩(wěn)定性,我向你推薦使用這個版本,使用這個版本你將會得到令人驚奇的性能。

1.1.1版本的asm來源自objectweb的asm項目,根據(jù)fastjson的需要做裁剪,確保引入asm的同時不引起包大小的過渡變大。

為了更好使用sort field martch優(yōu)化算法提升parser的性能,fastjson序列化的時候,缺省把SerializerFeature.SortField特性打開了。反序列化的時候也缺省把SortFeidFastMatch的選項打開了。這樣,如果你用fastjson序列化的文本,輸出的結(jié)果是按照fieldName排序輸出的,parser時也能利用這個順序進(jìn)行優(yōu)化讀取。這種情況下,parser能夠獲得非常好的性能。

我使用github.com/eishay/jvm-serializers/提供的程序做測試,性能數(shù)據(jù)如下:

 序列化時間反序列化時間大小壓縮后大小
java序列化854643199889541
hessian664310043501313
protobuf30081694239149
thrift31821951349197
avro35752095221133
json-lib45734149741485263
jackson32452986503271
fastjson22921499468251

測試跑的腳本是:

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

從上面的數(shù)據(jù)來看,fastjson的性能已經(jīng)超越protobuf、thrift、avro這些二進(jìn)制協(xié)議了。一個文本協(xié)議的性能超越二進(jìn)制協(xié)議是很難的,我很高興向大家宣布我做到了?。?/p>

鑒于fastjson優(yōu)越的性能表現(xiàn),我建議做如下事情;
1、替換其他所有的json庫,java世界里沒有其他的json庫能夠和fastjson可相比了。
2、使用fastjson的序列化和反序列化替換Java serialize,java serialize不單性能慢,而且體制大。
3、使用fastjson替換hessian,json協(xié)議不必hessian體積大,而且fastjson性能優(yōu)越,數(shù)倍于hessian
4、把fastjson用于memached緩存對象數(shù)據(jù)。

如何得到它?

如果您是Maven用戶,只需使用我們的Maven存儲庫即可(http://code.alibabatech.com/mvn/releases/)具有后續(xù)依賴性

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

關(guān)于高性能JSON開發(fā)包FastJson怎么用問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI