Fastjson如何处理超大JSON文本呢?
下文笔者讲述Fastjson处理超大文本的方法
序列化
超大JSON数组序列化
JSON格式是一个巨大的JSON数组
有很多元素
则先调用startArray
然后依次写入对象
然后调用endArray
JSONWriter writer = new JSONWriter(new FileWriter("/tmp/test.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/test.json"));
writer.startObject();
for (int i = 0; i < 1000 * 1000; ++i) {
writer.writeKey("x" + i);
writer.writeValue(new VO());
}
writer.endObject();
writer.close();
反序列化
JSONReader reader = new JSONReader(new FileReader("/tmp/test.json"));
reader.startArray();
while(reader.hasNext()) {
VO vo = reader.readObject(VO.class);
// handle vo ...
}
reader.endArray();
reader.close();
例
JSONReader reader = new JSONReader(new FileReader("/tmp/test.json"));
reader.startObject();
while(reader.hasNext()) {
String key = reader.readString();
VO vo = reader.readObject(VO.class);
// handle vo ...
}
reader.endObject();
reader.close();
版权声明
本文仅代表作者观点,不代表本站立场。
本文系作者授权发表,未经许可,不得转载。


