java语言最快的json库fastjson发布1.1.32版本,这个版本增加了stream api,支持处理超大json文本
Bug
- [FASTJSON-208] - 反序列化无setter集合属性返回为null时空指针异常
- [FASTJSON-209] - JSONField(serialize=false)配置在字段上不起作用
- [FASTJSON-211] - ThrowableDeserializer处理null出错
Improvement
- [FASTJSON-210] - 支持流式反序列化
- [FASTJSON-212] - parser自动识别更多日期格式
当需要处理超大JSON文本时,需要Stream API,在fastjson-1.1.32版本中开始提供Stream API。
# 序列化
## 例1
- JSONWriter writer = new JSONWriter(new FileWriter("/tmp/huge.json"));
- writer.startArray();
- for (int i = 0; i < 1000 * 1000; ++i) {
- writer.writeValue(new VO());
- }
- writer.endArray();
- writer.close();
## 例2
- JSONWriter writer = new JSONWriter(new FileWriter("/tmp/huge.json"));
- writer.startObject();
- for (int i = 0; i < 1000 * 1000; ++i) {
- writer.writeKey("x" + i);
- writer.writeValue(new VO());
- }
- writer.endObject();
- writer.close();
# 反序列化
## 例3
- JSONReader reader = new JSONReader(new FileReader("/tmp/huge.json"));
- reader.startArray();
- while(reader.hasNext()) {
- VO vo = reader.readObject(VO.class);
- // handle vo ...
- }
- reader.endArray();
- reader.close();
## 例4
- JSONReader reader = new JSONReader(new FileReader("/tmp/huge.json"));
- reader.startObject();
- while(reader.hasNext()) {
- String key = reader.readString();
- VO vo = reader.readObject(VO.class);
- // handle vo ...
- }
- reader.endObject();
- reader.close();
原文链接:http://code.alibabatech.com/wiki/display/FastJSON/Home
译文链接:http://www.oschina.net/news/41699/fastjson-1-1-32