性能優化之解析:fastJson快速解析大數據json

在上一篇線程池中提到了最近寫的服務,要求實時與效率,在測試到3W數據的時候發現瞭解析JSON比較慢。

於是,使用阿里爸爸的fastJson進行嘗試,結果提升很多倍。不愧號稱第一快的解析包。

廢話不說了直接上代碼與圖。

以前:

/**
     * 將json字符串轉成List<Map<String, String>>
     */
    public final static List<Map<String, String>> jsonStringToList(String json) throws Exception{
JSONArray arry = JSONArray.fromObject(json);//這個過程很慢需要3秒多(3W數據)
List<Map<String, String>> rsList = new ArrayList<Map<String, String>>(arry.size());
Map<String, String> map;
for (int i = 0; i < arry.size(); i++) {
JSONObject jsonObject = arry.getJSONObject(i);
map = new HashMap<String, String>();
for (Iterator<?> iter = jsonObject.keys(); iter.hasNext();) {
String key = (String) iter.next();
String value = jsonObject.get(key).toString();
map.put(key, value);
}
rsList.add(map);
}
return rsList;
}

這是解析3Wjson數據的效率。

再看阿里爸爸的jar:

/**
     * fastJson 解析json串
     * @param json
     * @return
     */
    public static List<Map<String, String>> jsonToList(String json){
    JSONReader reader = new JSONReader(new StringReader(json));//已流的方式處理,這裏很快
reader.startArray();
List<Map<String, String>> rsList = new ArrayList<Map<String, String>>();
Map<String, String> map = null;
int i = 0;
while (reader.hasNext()) {
i++;
reader.startObject();//這邊反序列化也是極速
map = new HashMap<String, String>();
while (reader.hasNext()) {
String arrayListItemKey = reader.readString();
String arrayListItemValue = reader.readObject().toString();
map.put(arrayListItemKey, arrayListItemValue);
}
rsList.add(map);
reader.endObject();
}
reader.endArray();
return rsList;
    }


提升很多倍!!!

百度了一下原理,他們在序列化與反序列化上做了極大的功夫。現在沒時間研究了,過了這個測試期再研究原理吧。

我要去接着優化去了。優化無止境!!!!!!!!!

需要解析大數據的朋友直接拿去用就OK了。


針對優化方案另外補充一點:大量使用反射的時候不要每次都去get內些參數巴拉巴拉的,初始化的時候把需要的反射信息加到緩存裏。以後用的時候可以直接get,數據越多提升越大。


--做自己的百度,人。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章