您好,登錄后才能下訂單哦!
高性能JSON開發包FastJson怎么用,針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
Fastjson介紹
Fastjson是一個Java語言編寫的JSON處理器,由阿里巴巴公司開發。
1、遵循http://json.org標準,為其官方網站收錄的參考實現之一。
2、功能qiang打,支持JDK的各種類型,包括基本的JavaBean、Collection、Map、Date、Enum、泛型。
3、無依賴,不需要例外額外的jar,能夠直接跑在JDK上。
4、開源,使用Apache License 2.0協議開源。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轉換為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算法提高性能,由于過于著急展示其優越的性能,沒有進行嚴格測試就發布了。
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優越的性能表現,我建議做如下事情;
1、替換其他所有的json庫,java世界里沒有其他的json庫能夠和fastjson可相比了。
2、使用fastjson的序列化和反序列化替換Java serialize,java serialize不單性能慢,而且體制大。
3、使用fastjson替換hessian,json協議不必hessian體積大,而且fastjson性能優越,數倍于hessian
4、把fastjson用于memached緩存對象數據。
如何得到它?
如果您是Maven用戶,只需使用我們的Maven存儲庫即可(http://code.alibabatech.com/mvn/releases/)具有后續依賴性
<dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.1.1</version> </dependency>
關于高性能JSON開發包FastJson怎么用問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。