fastjson 1.1.32 发布,Java 的 JSON 库

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();    

相关推荐