在上一篇线程池中提到了最近写的服务,要求实时与效率,在测试到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,数据越多提升越大。
--做自己的百度,人。