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