性能优化之解析: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,数据越多提升越大。


--做自己的百度,人。

  • 5
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值