Fastjson API 串流
Fastjson當需要處理超大JSON文字時,需要Stream API,在fastjson-1.1.32版本中開始提供Stream API。
序列化
#超大JSON陣列序列化
如果你的JSON格式是一個巨大的JSON數組,有很多元素,則先呼叫startArray,然後挨個寫入對象,然後呼叫endArray。
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();
超大JSON物件序列化
如果你的JSON格式是一個巨大的JSONObject,有很多Key/Value對,則先呼叫startObject,然後挨個寫入Key和Value,然後呼叫endObject。
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();