8

我有一个需要反序列化的大型 json 数据集。我正在使用 Json.netJsonTextReader来读取数据。

我的问题是我需要反序列化一些派生类,所以我需要能够“向前看”定义我的数据类型的特定属性。在下面的示例中,“type”参数用于确定要反序列化的对象类型。

{
  type: "groupData",
  groupParam: "groupValue1",
  nestedObject: 
  {
    type: "groupData",
    groupParam: "groupValue2",
    nestedObject:
    {
      type: "bigData",
      arrayData: [ ... ]
    }
  }

我的派生对象可以重度嵌套并且非常深。不需要将整个数据集加载到内存中,因为它需要大量内存。一旦我深入到“bigData”对象,我将处理数据(例如上面示例中的数组),但它不会存储在内存中(它太大了)。

到目前为止,我看到的所有问题的解决方案都用于JObject反序列化部分对象。我想避免使用JObject,因为它会反复反序列化层次结构中的每个对象。

如何解决我的反序列化问题?

有没有办法提前搜索“type”参数,然后回溯到对象的 { 字符的开头开始处理?

4

1 回答 1

1

无论如何,我都不知道要预先加载对象以指定前瞻(至少在 Json.NET 中没有),但您可以使用其他基于属性的配置项来忽略不需要的属性:

public class GroupData {
    [JsonIgnore]
    public string groupParam { get; set; }
    [JsonIgnore]
    public GroupData nestedObject { get; set; }

    public string[] arrayData { get; set; }
}

或者,您可以尝试自定义创建转换器:

例如..

public class GroupData {
    [JsonIgnore]
    public string groupParam { get; set; }
    [JsonIgnore]
    public GroupData nestedObject { get; set; }
}

public class BigData : GroupData {
    public string[] arrayData { get; set; }
}

public class ObjectConverter<T> : CustomCreationConverter<T>
{
    public ObjectConverter() { }

    public override bool CanConvert(Type objectType)
    {
        return objectType.Name == "BigData";
    }

    public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer)
    {
        // Some additional checks/work?
       serializer.Populate(reader, target);
    }
}
于 2014-02-17T09:19:53.787 回答